《汇编语言第2版王爽著课后实验报告详解.doc》由会员分享,可在线阅读,更多相关《汇编语言第2版王爽著课后实验报告详解.doc(17页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、 汇编语言实验报告 班级学号学生姓名提交日期成 绩实验1-1如下:用E命令将指令写入内存:用A命令将指令写入内存:实验1-2代码如下:用a命令在2000:0000处写如要写如的代码,然后用R命令来修改CS为2000,IP修改为0,然后用T命令执行,直到AX中的值为10,因为是默认为十六进制,所以ax中的0010实际代表十进制的16。如图:实验1-3:用D命令输入内存fff0hfffffh,那么可看到:生产日期为06/15/09在地址为FFFF5FFFF12处,现在用E命令随便修改一下有:在window7下虚拟的dos中可以改,但如果重新翻开dos中的debug那么日期任然不会改变,因为那是RO
2、M。实验1-4代码如下:内存地址为B800:0开场的为显存,是RAM,可以改变其值来在屏幕中显示,其中这一个字符占两个字节,前一个低为字符的ASCII码,后一个高为要显示的颜色,内存B800:0和B800:1这两个字节对应着屏幕中的第一个字符的位置,依次类推,每个屏幕的行有80个字符,对应的内存占160个字节实验2-1:按实验结果填空Mov ax,ffffMov ds,axMov ax,2200Mov ss,axMov sp,0100Mov ax,0 ;ax=5BEAAdd ax,2 ;ax=5CCAMov bx,4 ;bx=30F0Add bx,6 ;bx=6026Push ax ;sp=0
3、0FE; 修改的内存单元的地址是2200:00FE 内容是5CCAPush bx ;sp=00FC; 修改的内存单元的地址是2200:00FC 内容是 6026Pop ax ;sp=00FE; ax=6026.Pop bx ;sp=0100; bx=.5CCAPush 4 ;sp=00FE; 修改的内存单元的地址是2200:00FE 内容是 30F0Push 6 ;sp=00FC; 修改的内存单元的地址是 2200:00FC内容是 2F36实验截图如下:实验2-2分析问答实验答:因为T命令是单步中断,我们在后面学习后知道,CPU执行中断时会保存现场,即将标志存放器,CS,IP等入栈,而实验中栈
4、的地址正好是要查询的内存地址,所以即便未对内存单元进展写入命令,但里面的值会因为CPU要保存现场自动被改了实验1代码: ASSUME CS:CODESCODES SEGMENTSTART: mov ax,2000h mov ss,ax mov sp,0 add sp,10 pop ax pop bx push ax push bx pop ax pop bx MOV AH,4CH INT 21HCODES ENDS END START(2) debug跟踪:(3) 用debug跟踪查看PSP中的内容:可见PSP的头两个字节是CD 20,与书上的一致实验4-1代码如下: ASSUME CS:CO
5、DESCODES SEGMENTSTART: mov ax,0 mov ds,ax mov bx,200h mov cx,64s: mov bx,al inc al inc bx loop s MOV AH,4CH INT 21HCODES ENDSEND START实验4-1运行图如下:实验4-2代码如下: ASSUME CS:CODESCODES SEGMENTSTART: mov ax,200h mov ds,ax mov bx,0 mov cx,64s: mov bx,bx inc bx loop s MOV AH,4CH INT 21HCODES ENDS END START运行结果
6、同实验4-1的一样实验4-3补全代码 ASSUME CS:CODESCODES SEGMENTSTART: mov ax,cs mov ds,ax mov ax,20h mov es,ax mov bx,0 mov cx,16hs: mov al,bx mov es:bx,al inc bx loop s MOV AH,4CH INT 21HCODES ENDSEND START因为要将代码复制到0:200处,那么必须知道代码的地址,和代码的长度,代码的地址在cs和IP中,代码的长度可以编译后用U命令查看后确定,这个之前随便打一个数就可以,不影响代码的长度,因为那个数占的空间和真实的长度一样,
7、所以用U命令后在改正来即可实验4-3的运行图如下:实验5-1代码如下:DATAS SEGMENT dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987hDATAS ENDSSTACKS SEGMENT dw 0,0,0,0,0,0,0,0STACKS ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATAS,SS:STACKSSTART: MOV AX,stacks MOV ss,AX mov sp,16 mov ax,datas mov ds,ax push ds:0 push ds:2 pop ds:2 pop ds
8、:0 MOV AH,4CH INT 21HCODES ENDS END START实验5-1运行图如下:CPU执行程序后,程序返回前,data段中的数据为多少?答:不变如上图CPU执行程序后,程序返回前,CS=144Ch,SS=144Bh,DS=144Ah。设程序加载后,code段的段地址为X,那么data段的段地址为X-2,stack段的段地址为X-1.实验5-2代码如下:ASSUME CS:CODES,DS:DATAS,SS:STACKSDATAS SEGMENT dw 0123h,0456h DATAS ENDSSTACKS SEGMENT dw 0,0STACKS ENDSCODES
9、SEGMENTSTART: MOV AX,stacks MOV sS,AX mov sp,16 mov ax,datas mov ds,ax push ds:0 push ds:2 pop ds:2 pop ds:0 MOV AH,4CH INT 21HCODES ENDS END START实验5-2运行图如下:CPU执行程序后,程序返回前,data段中的数据为多少?答:不变如上图CPU执行程序后,程序返回前,CS=144Ch,SS=144Bh,DS=144Ah。设程序加载后,code段的段地址为X,那么data段的段地址为X-2,stack段的段地址为X-1.对于如下定义的段:Name s
10、egmentName ends如果段中的数据占N个字节,那么程序加载后,该段实际占用空间为16N倍。实验5-3代码如下:CODES SEGMENT ASSUME CS:CODES,DS:DATAS,SS:STACKSSTART: MOV AX,stacks MOV sS,AX mov sp,16 mov ax,datas mov ds,ax push ds:0 push ds:2 pop ds:2 pop ds:0 MOV AH,4CH INT 21HCODES ENDSDATAS SEGMENT dw 0123h,0456hDATAS ENDSSTACKS SEGMENT dw 0,0STA
11、CKS ENDS END START实验5-3运行图如下:CPU执行程序后,程序返回前,data段中的数据为多少?答:不变如上图CPU执行程序后,程序返回前,CS=144Ch,SS=144Eh,DS=144Dh。设程序加载后,code段的段地址为X,那么data段的段地址为X+3,stack段的段地址为X+4。实验5-4:如果将1,2,3题中的最后一条伪指令“end start改为“end也就是说,不指明程序的入口,那么哪个程序任然可以正确执行?答:程序都可以正确执行,因为去掉start后,由于没有的标志,系统会将从code段的起始位置当作程序代码的开场处,然后一直执行下去,而这三个程序在st
12、art前没有其他的内容,去掉start也就不影响期功能了实验5-5代码如下: ASSUME CS:CODESCODES SEGMENT a SEGMENT db 1,2,3,4,5,6,7,8 a ENDSb SEGMENT db 1,2,3,4,5,6,7,8b ENDSCC SEGMENT db 0,0,0,0,0,0,0,0CC ENDSSTART: MOV AX,a MOV DS,AXmov si,0Mov cx,8s: mov ax,0 add al,0+siadd al,16+siMov 32+si,al inc si loop s MOV AH,4CH INT 21HCODES
13、ENDS END START实验5-5运行图如下:实验5-6代码如下:a SEGMENT dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffha endsb SEGMENT dw 0,0,0,0,0,0,0,0b ENDSCODES SEGMENT ASSUME CS:CODESSTART: MOV AX,a MOV DS,AX mov bx,0 mov ax,b mov ss,ax mov sp,16 mov cx,8s: push bx add bx,2 loop s MOV AH,4CH INT 21HCODES ENDS END START
14、实验5-6运行图如下:实验6代码如下:stacksg SEGMENT dw 0,0,0,0,0,0,0,0stacksg ENDSdatasg SEGMENT db 1. display db 1. brows db 1. replace db 1. modifly datasg ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATASg,SS:STACKSgSTART: MOV AX,DATASg MOV DS,AX mov bx,0 mov ax,stacksg mov ss,ax mov sp,16 mov cx,4s0: push cx mov si,3 m
15、ov cx,4s: mov al,bx+si and al,11011111b mov bx+si,al inc si loop s add bx,16 pop cx loop s0 MOV AH,4CH INT 21HCODES ENDS END START实验6运行图如下:实验7代码如下:DATAS SEGMENT Db1975,1976,1977,1978,1979,1980,1981,1982,1983,1984,1985,1986,1987,1988,1989,1990,1991,1992,1993,1994,1995 dd 16,22,382,1356,2390,8000,1600
16、0,24486,50065,97497,140417,197514dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226dw 11542,11430,15257,17800DATAS ENDStable SEGMENT db 21 dup(year summ ne ? )table ENDSCODES SEGMENT ASSUME CS:CODESSTART: MOV AX
17、,DATAS MOV DS,AX mov bp,0 mov ax,table mov es,ax mov di,0 mov bx,0 mov cx,21 ;循环21次,因为有21行s: mov si,0 ;将年份入表mov ax,ds:si+bp ;si是首地址,bp是相对si的偏移地址,bp每次加4 mov es:di,ax mov ax,ds:si+bp+2 mov es:di+2,ax mov si,84 ;将总收入入表 mov ax,ds:si+bp mov es:di+5,ax mov ax,ds:si+bp+2 mov es:di+7,ax mov si,168 ;将人数入表 mo
18、v ax,ds:si+bx ;bx和bp的功能一样,只不过因为它只能每次加2 mov es:di+10,ax mov ax,es:di+5 ;求人均收入并入表 mov dx,es:di+7 div word ptr es:di+10 mov es:di+13,ax add di,16 add bp,4 add bx,2 loop s MOV AH,4CH INT 21HCODES ENDSEND START实验7运行图如下:实验8代码如下:CODES SEGMENT ASSUME CS:CODES mov ax,4c00h int 21h START: MOV AX,0 s: nop nop
19、mov di,offset s mov si,offset s2 mov ax,cs:si mov cs:di,axso: jmp short ss1: mov ax,0 int 21h mov ax,0s2: jmp short s1 nop CODES ENDSEND START程序能正常执行完毕,因为在start后的第7,8行将s2处的代码写入了s处的两个空字节单元,而内容为EBF0,意思是从将当前IP的值赋成IP-F0八位位移,补码形式,赋值后IP指向了mov ax,4c00h,接着就完毕程序了实验9代码如下:DATAS SEGMENT dbwelcome to masm! DATAS
20、 ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATASSTART: MOV AX,DATAS MOV DS,AX mov bx,0 mov ax,0b800h mov es,ax mov si,1980 ;将显示的区域定在屏幕中间 mov cx,16s: mov al,bx mov es:si,al mov ah,01110010b ;将颜色定为绿色 mov es:si+1,ah add si,2 inc bx loop s mov bx,0 mov si,2140 ;下一行接着从来 mov cx,16s1: mov al,bx mov es:si,al mov
21、 ah,00100100b ;颜色为绿底红色 mov es:si+1,ah add si,2 inc bx loop s1 mov bx,0 mov si,2300 ;同上 mov cx,16s2: mov al,bx mov es:si,al mov ah,01110001b mov es:si+1,ah add si,2 inc bx loop s2 MOV AH,4CH INT 21HCODES ENDS END START实验9运行图如下:实验10-1代码如下:DATa SEGMENT db welcome to masm!,0DATA ENDSCODES SEGMENT ASSUME
22、 CS:CODESSTART: mov dh,8 mov dl,3 mov cl,2 MOV AX,DATA MOV DS,AX mov si,0 call show_str MOV AH,4CH INT 21Hshow_str: mov ax,data mov ds,ax mov si,0 mov ax,0b800h mov es,ax mov al,160 ; 将乘数行数默认放在al中 mul dh ;想乘之后结果放在ax行的偏移地址中 mov dh,0 add dl,dl ;因为一个字符用两个字节,所以二倍,及列数的偏移地址 add ax,dx 将列的加到行上就是偏移地址了 mov bx
23、,ax ;bx为偏移地址 s:mov cl,2 mov ch,0 mov al,si mov ah,0 ;开场复制字符到显存中 mov es:bx,al mov es:bx+1,cl ;设置颜色 mov cx,ax inc cx ;判断cx是否为0 jcxz ok inc si add bx,2 loop sok: ret CODES ENDS END START实验10-1运行图如下:实验10-2代码如下:CODES SEGMENT ASSUME CS:CODESSTART: mov ax,4240h mov dx,00fh mov cx,0ah call divdw MOV AH,4CH
24、INT 21H divdw: mov di,ax ;将ax中的4240先保存起来 mov ax,dx ;将dx中ooof赋给在ax mov dx,0 div cx mov si,dx ; 将余数先存到si中,因为后面马上会占用dx mov dx,ax ;将取商的值赋给dx,这里的dx为高位 push dx mov dx,si ;将余数放入dx中 mov ax,di div cx mov cx,dx pop dx retCODES ENDSEND START实验10-2运行图如下:实验10-3代码如下:DATa1 SEGMENT dw 123,12666,1,8,3,38 DATA1 ENDSd
25、ata2 SEGMENT db 16 dup(0)data2 ENDSdata3 segment db 16 dup(0)data3 endsCODES SEGMENT ASSUME CS:CODESSTART: MOV AX,DATA1 MOV DS,AX mov bx,0 mov cx,6 call dtoc ;调用dtoc子程序 mov dh,8 mov dl,3 mov cl,2 mov ch,0 call show_str ;调用show_str子程序 MOV AH,4CH INT 21Hdtoc: mov ax,data2 ;data2中是用来存放字符的,不过是反顺序的“123在其
26、中变成了“321 mov es,ax mov di,0 mov bp,0s1: push cx ;cx入栈,保存起来 mov ax,bxs2: mov dx,0 ;因为12666%10的结果会溢出,所以有32位当被乘数,ax中存放商 mov cx,10 div cx add dl,30h ;加上30h后就变成ascii对应的字符码了 mov es:di,dl ;存入data2段中 mov cx,ax ;判断商是否为零,为零那么完毕循环 jcxz ok inc di jmp s2ok: push ds ;因为后面用到ds,而前面又有,所以保存push di sub di,1 ;因为di指向的后一
27、个元素,这里减一使其回到当前元素Mov di,dx ;当前的值保存到dx中 mov ax,data3 ;data2中数据为“,这里将其反置为“ mov ds,axs3: mov al,es:dimov ds:bp,al cmp dx,bp ;判断反序复制是否完毕的,bp到达原来di所指向的元素那么完毕 je ok1 inc bp ;反序 dec di jmp s3ok1:add bx,2 pop di ;按顺序复原 pop ds pop cx loop s1 retshow_str: mov ax,data3 ;显示字符的子程序,前面已做过 mov ds,ax mov si,0 mov ax,0b800h mov es,ax mov al,160 mul dh mov dh,0 add dl,dl add ax,dx mov bx,ax s:mov cx,2 mov al,si mov ah,0 mov es:bx,al mov es:bx+1,cl add bx,2 mov cx,ax inc cx inc si loop sok2: ret CODES ENDS END START实验10-3运行图如下: