ImageVerifierCode 换一换
格式:DOCX , 页数:77 ,大小:184.24KB ,
资源ID:16728366      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/16728366.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(汇编课后答案Word文档格式.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

汇编课后答案Word文档格式.docx

1、 xlat ;转换为格雷码,AL12H P35习题什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令 堆栈是一种按“先进后出”原则存取数据的存储区域,位于堆栈段中,使用SS段寄存器记录其段地址;它的工作原则是先进后出;堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。习题已知SS = 2200H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化 mov ax,8057h push ax mov ax,0f79h pop bx pop bx mov ax,0f79h pop bx ;bx=0f79h pop bx ;DS:0f79h=80

2、57h习题给出下列各条指令执行后AL值,以及CF、ZF、SF、OF和PF的状态: mov al,89h add al,al add al,9dh cmp al,0bch sub al,al dec al inc almov al,89h ; AL=89h CF ZF SF OF PFadd al,al ; AL=12h 1 0 0 1 1; 1000 1001+1000 1001 10001 0010 add al,9dh ; AL=0afh 0 0 1 0 1 0001 0010+ 1001 1101 1010 1111 cmp al,0bch ; AL=0afh 1 0 1 0 1 101

3、0 1111-1011 1100* 0100 0011sub al,al ; AL=00h 0 1 0 0 1dec al ; AL=0ffh 0 0 1 0 1 0000 0000- 0000 0001*1111 1111inc al ;1111 1111+0000 0001习题设X、Y、Z均为双字数据,分别存放在地址为X、X+2;Y、Y+2;Z、Z+2的存储单元中,它们的运算结果存入W单元。阅读如下程序段,给出运算公式。 mov ax,X mov dx,X+2 add ax,Y adc dx,Y+2 add ax,24 adc dx,0 sub ax,Z sbb dx,Z+2 mov W,

4、axmov W+2,dx WX+Y+24-Z习题请分别用一条汇编语言指令完成如下功能:(1)把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器。(2)用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中。(3)用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和CX寄存器的内容相加,并把结果送回存储器中。(4)用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中。(5)把数0A0H与AL寄存器的内容相加,并把结果送回AL中。(1)ADD DX,BX(2)ADD AL,BX+SI(3)ADD B

5、X+0B2H,CX(4)ADD WORD PTR 0520H,3412H(5)ADD AL,0A0H习题设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。 mov ax,X ;ax=X imul Y ;=X*Y mov cx,ax ;cx=X*Y的低16位 mox bx,dx ;bx=X*Y的高16位 mov ax,Z ;ax=Z cwd add cx,ax ;cx=Z的低16位+X*Y的低16位 adc bx,dx ;bx=Z的高16位+X*Y的高16位+低位进位 sub cx,540 ;cx=Z的低16位+X*Y

6、的低16位-540 sbb bx,0 ;bx=Z的高16位+X*Y的高16位+低位进位-低位借位 mov ax,V ;ax=V sub ax,cx ;ax=V的低16位-(Z的低16位+X*Y的低16位-540) sbb dx,bx ;dx=V的高16位-(Z的高16位+X*Y的高16位+低位进位-低位借位)-低位借位 idiv X ;/X V-(X*Y+Z-540)/X AX存商,DX存余数 习题指出下列指令的错误:(1) xchg si,30h(2) pop cs(3) sub si,di(4) push ah(5) adc ax,ds(6) add si,80h(7) in al,3fc

7、h(8) out dx,ah(1)xchg的操作数不能是立即数(2)不应对CS直接赋值(3)两个操作数不能都是存储单元(4)堆栈的操作数不能是字节量(5)adc的操作数不能是段寄存器(6)没有确定是字节还是字操作(7)in不支持超过FFH的直接寻址(8)out只能以AL/AX为源操作数习题给出下列各条指令执行后的结果,以及状态标志CF、OF、SF、ZF、PF的状态。 mov ax,1470h and ax,ax or ax,ax xor ax,ax not ax test ax,0f0f0h解答 mov ax,1470h ;AX1470H CF ZF SF OF PF and ax,ax ;A

8、X1470H 0 0 0 0 0 ;0001 0100 0111 0000 or ax,ax ; xor ax,ax ;AX0000H 0 1 0 0 1 not ax ;AXFFFFH 0 1 0 0 1 test ax,0f0f0h ;AXFFFFH 0 0 1 0 1注意:MOV和NOT指令不影响标志位;其他逻辑指令使CFOF0,根据结果影响其他标志位。习题假设例题的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结果和各个标志位的状态。 指令 ; 执行结果 CF OF SF ZF PF mov si,ax ; SI=AX=0008H - - - - - shl si

9、,1 ; SI=2*AX=0010H0 0 0 0 0 add si,ax ; SI=3*AX=0018H 0 0 0 0 1 mov dx,bx; DX=BX=0010H 0 0 0 0 1 mov cl,03h; CL=03H0 0 0 0 1 shl dx,cl ; DX=8*BX=0080H 0 u 0 0 0 sub dx,bx ; DX=7*BX=0070H 0 0 0 0 0 add dx,si; DX=7*BX+3*AX=0088H0 0 0 0 1逻辑左移N次相当于无符号整数乘以2的N次方,逻辑右移N次相当于无符号整数除以2的N次方。移位指令根据移位的数据设置CF,根据移位后

10、的结果影响SF,ZF,PF。在进行一位移位时,根据最高符号位是否改变设置OF,如改变则OF1。另外,程序注释用“u”表示标志无定义(不确定),“-”表示无影响。习题编写程序段完成如下要求:(1)用位操作指令实现AL(无符号数)乘以10(2)用逻辑运算指令实现数字0 9的ASCII码与非压缩BCD码的互相转换(3)把中的双字右移4位(1);不考虑进位 mov bl,al mov cl,3 shl al,cl ;*8 add al,bl ;shl bl,1 add al,bl ;考虑进位 xor ah,ah mov bx,ax shl ax,cl add ax,bx ;shl bx,1 add a

11、x,bx(2)数字09的ASCII码是:30h39h 非压缩BCD码的09是:00h09h方法一: and al,0fh ;实现ASCII到非压缩BCD码的转换 or al,30h ;实现非压缩BCD码到ASCII的转换方法二: xor al,30h ;求反D5D4位,其他不变即高4位为3,则变为0;高4位为0,则变为3(3) mov cl,4again:shr dx,1 ;实现逻辑右移采用“sar dx,1”,则实现算术右移 rcr ax,1dec cl jnz again习题已知AL = F7H(表示有符号数-9),分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得

12、的商是什么 (1)用sar编写 mov al,0f7h ; -9送AL 1111 1001 sar al,1 ; 结果:AL=1111 1100B=0FBH 即-5(2)用idiv编写 -9送al cbw ; 字节符号扩展位字 mov bl,2 ; 注意除数不可为立即数 idiv bl ;商为al=fch (-4) 余数:ah=ffh (-1) 结论:符号数的除法用idiv 准确。习题已知数据段500h 600h处存放了一个字符串,说明下列程序段执行后的结果: mov si,600h mov di,601h mov ax,ds mov es,ax mov cx,256 std rep movs

13、b习题说明下列程序段的功能 cld mov ax,0fefh mov cx,5 mov bx,3000h mov es,bx mov di,2000h rep stosw将es:di (即3000:2000h或32000h)开始的5个单元的内容置为0fefh。习题指令指针IP是通用寄存器还是专用寄存器有指令能够直接它赋值吗哪类指令的执行会改变它的值 指令指针IP不是通用寄存器,不可直接赋值,属于专用寄存器。有且仅有循环、转移、子程序调用和返回、中断类等指令可以改变它的值。习题控制转移类指令中有哪三种寻址方式 控制转移类指令的寻址方式:相对寻址、直接寻址方式和间接寻址方式(又可以分成寄存器和存储

14、器间接寻址)。习题什么是短转移short jump、近转移near jump和远转移far jump什么是段内转移和段间转移8086有哪些指令可以实现段间转移 短转移:指段内128127之间的转移,位移量用一个字节表示近转移:指段内32K之间的转移,位移量用一个字表示远转移:指段间1MB范围的转移段内转移:指在同一个代码段内的转移,可以是短转移或者近转移段间转移:指转移到另外一个代码段,就是远转移8086/8088CPU的JMP、CALL和INT n指令可以实现段间转移习题8086的条件转移指令的转移范围有多大实际编程时,你如何处理超出范围的条件转移 8086的条件转移的转移范围:在当前指令地

15、址的 +127-128之内。如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围外的目标地址。习题假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,232F7H=3280H,264E5H=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么 (1) JMP BX(2) JMP TABLEBX(3) JMP BXSI(1)转移的有效地址EA= BX=1256H(2)转移的有效地址EA= DS:20A1H+1256H=232F7=3280H(3)转移的有效地址EA= DS:1256H+528FH=264E5H=2450

16、H习题判断下列程序段跳转的条件 (1) xor ax,1e1eh je equal (2)test al,b jnz there (3)cmp cx,64h jb there(1)AX1e1eh(异或后为0)(2)AL的D0或D7至少有一位为1(3)CX(无符号数) 64h习题设置CX = 0,则LOOP指令将循环多少次例如:mov cx,0delay:loop delay 216次。习题假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:(1)若DX DI,转到above执行;(2)若AX SI,转到greater执行;(3)若CX = 0,转

17、到zero执行;(4)若AXSI产生溢出,转到overflow执行;(5)若SIAX,转到less_eq执行;(6)若DIDX,转到below_eq执行。 DI,转到above执行 cmp dx,di ja above ;jnbe above SI,转到greater执行 cmp ax,si jg greater ;jnle greater(3)若CX = 0,转到zero执行 cmp cx,0 jz zero ; jcxz zero jo overflow cmp si,ax ; jle less_eq ; jge less_eq cmp di,dx ; jbe below_eq ; jae

18、 below_eq习题有一个首地址为array的20个字的数组,说明下列程序段的功能。 mov cx,20 mov ax,0 mov si,axsum_loop: add ax,arraysi add si,2 loop sum_loop mov total,ax将首地址为array得20个字的数组求和,并将结果存入 total 单元中。习题按照下列要求,编写相应的程序段:(1)起始地址为string的主存单元中存放有一个字符串(长度大于6),把该字符串中的第1个和第6个字符(字节量)传送给DX寄存器。(2)从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低(高)地址对低(高)

19、位的原则,将它们合并到DX中。(3)编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1。(4)有两个64位数值,按“小端方式”存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1buffer2功能。(5)假设从B800h : 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在中。(6)已知字符串string包含有32KB内容,将其中的$符号替换成空格。(7)有一个100个字节元素的数组,其首地址为array,将每个元素减1(不考虑溢出)存于原处。(8)统计以 $ 结尾的字符串srting的字符个数。(1)解答: mov s

20、i,0 mov dl,stringsi ;第1个字符送dl寄存器:mov dl,stirng0 mov si,5 mov dh,stringsi ;第6个字符送dh寄存器:mov dl,stirng5(2)解答: xor si,si ;si清零 mov al,buffersi ;第一字节 inc si mov ah,buffersi ;第二字节 mov cl,4 shl ah,cl ;BCD码移到高半字节 or al,ah ;组合成压缩BCD码 mov dl,al ;存入dl寄.第三字节第四字节 mov dh,al ;存入dh寄.(3)解答: test dx,0f000h ; test dh,

21、0f0h jz next ; jnz next mov ax,-1 ; jmp againnext:mov ax,0 ; mov ax,0ffffh .(4)解答: mov ax, word ptr buffer1 sub ax, word ptr buffer2 ;先减低16位 mov dx, word ptr buffer1+2 sbb dx, word ptr buffer2+2 ;后减高16位,需减低16位的借位(5)解答: mov ax,0b800h mov ds,ax ;段地址地址偏移量si=0 xor dx,dx ;和的高字dx=0 mov cx,99 ;加的次数 mov ax,

22、si ;第一个数 inc si ;指向下一个字单元 add ax,si ;加下一个数 jnc noc ;无进位转 inc dx ;有进位dx=dx+1 noc: dec cx ;次数-1 jnz cx,again ;非0继续加 (6)解答1:不使用串操作指令(更好) mov si,offset string mov cx,8000h ; 32k=215=8000h cmp byte ptr si, $ ;$ 24h jnz next ; 不要采用 jz 进行分支 mov byte ptr si, ; 20h loop again ; dec cx(6)解答2:使用串操作指令 mov di,of

23、fset string mov al,$ mov cx,8000h scasb mov byte ptr es : di-1, loop again(7)解答1: mov si,offset array mov cx,100 dec byte ptr si(7)解答2: xor si,si ; si-0 mov cx,100 ; 循环次数 dec arraysi(7)解答3: mov si,offset array mov di,si mov ax,ds lodsb stosb(8)解答:sicoun: cmp stringsi,$ je done jmp coundone: . 习题对下面要求,分别给出3种方法,每种方法只用一条指令。(1)使CF=0 (2)使AX=0 (3)同时使AX=0和CF=0 clc and ax,0 sub ax,ax习题参照本习题的示意图,分析调用序列,画出每次调用及返回时的堆栈状态。其中CALL前是该指令所在的逻辑地址;另外,段内直接调用指令的机器代码的字节数为3,段间直接调用指令则为5个字节。主程序转子suba时段内调用:断点1为2000h:0400h+3,转子是只将IP压栈。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1