新版汇编语言程序设计【课后习题答案】 钱晓捷 主编 电子工业出版社.pdf
欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!11H、12H、14H,它存在于以 table 为首地址设为 200H的连续区域中。请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。lea bx,table mov al,8 xlat 解答 lea bx,table ;获取 table 的首地址,BX200H mov al,8 ;传送欲转换的数字,AL8 xlat ;转换为格雷码,AL12H P35 习题 2.4什么是堆栈,它的工作原那么是什么,它的根本操作有哪两个,对应哪两种指令?解答 堆栈是一种按“先进后出原那么存取数据的存储区域,位于堆栈段中,使用 SS 段存放器记录其段地址;它的工作原那么是先进后出;堆栈的两种根本操作是压栈和出栈,对应的指令是 PUSH 和 POP。习题 2.5SS=2200H、SP=00B0H,画图说明执行下面指令序列时,堆栈区和 SP 的内容如何变化?mov ax,8057h push ax mov ax,0f79h push ax pop bx pop bx 解答 mov ax,8057h push ax mov ax,0f79h push ax pop bx ;bx=0f79h pop bx ;DS:0f79h=8057h 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 2.6给出以下各条指令执行后 AL 值,以及 CF、ZF、SF、OF 和 PF 的状态:mov al,89h add al,al add al,9dh cmp al,0bch sub al,al dec al inc al 解答 mov al,89h ;AL=89h CF ZF SF OF PF add 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;1010 1111-1011 1100*0100 0011 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!sub al,al ;AL=00h 0 1 0 0 1 dec al ;AL=0ffh 0 0 1 0 1;0000 0000-0000 0001 *1111 1111 inc al ;AL=00h 0 1 0 0 1;1111 1111+0000 0001*1111 1111 习题 2.7设 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,ax mov W+2,dx 解答 WX+Y+24-Z 习题 2.8请分别用一条汇编语言指令完成如下功能:1把 BX 存放器和 DX 存放器的内容相加,结果存入 DX 存放器。2 用存放器 BX 和 SI 的基址变址寻址方式把存储器的一个字节与 AL 存放器的内容相加,并把结果送到 AL 中。3用 BX 和位移量 0B2H 的存放器相对寻址方式把存储器中的一个字和 CX 存放器的内容相加,并把结果送回存储器中。4 用位移量为 0520H 的直接寻址方式把存储器中的一个字与数 3412H 相加,并把结果送回该存储单元中。5把数 0A0H 与 AL 存放器的内容相加,并把结果送回 AL 中。解答 1ADD DX,BX 2ADD AL,BX+SI 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!3ADD BX+0B2H,CX 4ADD WORD PTR 0520H,3412H 5ADD AL,0A0H 习题 2.9设 X、Y、Z、V 均为 16 位带符号数,分别装在 X、Y、Z、V 存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。mov ax,X ;ax=X imul Y ;DX.AX=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 的低 16 位-540 sbb bx,0 ;bx=Z 的高 16 位+X*Y 的高 16 位+低位进位-低位借位 mov ax,V ;ax=V cwd 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 存余数 习题 2.10指出以下指令的错误: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,3fch 8 out dx,ah 解答 1xchg 的操作数不能是立即数 2不应对 CS 直接赋值 3两个操作数不能都是存储单元 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!4堆栈的操作数不能是字节量 5adc 的操作数不能是段存放器 6没有确定是字节还是字操作 7in 不支持超过 FFH 的直接寻址 8out 只能以 AL/AX 为源操作数 习题 2.11给出以下各条指令执行后的结果,以及状态标志 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 ;AX1470H 0 0 0 0 0 ;0001 0100 0111 0000 or ax,ax ;AX1470H 0 0 0 0 0 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,根据结果影响其他标志位。习题 2.12假设例题 2.32 的程序段中,AX=08H,BX=10H,请说明每条指令执行后的结果和各个标志位的状态。解答 指令 ;执行结果 CF OF SF ZF PF mov si,ax ;SI=AX=0008H -shl si,1 ;SI=2*AX=0010H 0 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=03H 0 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=0088H 0 0 0 0 1 注意:逻辑左移 N 次相当于无符号整数乘以 2 的 N 次方,逻辑右移 N 次相当于无符号整数除以 2 的 N 次方。移位指令根据移位的数据设置 CF,根据移位后的结果影响 SF,ZF,PF。在进行一位移位时,根据最高符号位是否改变设置 OF,如改变那么 OF1。另外,程序注释用“u表示标志无定义不确定,“-表示无影响。欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 2.13编写程序段完成如下要求:1用位操作指令实现 AL无符号数乘以 10 2用逻辑运算指令实现数字 0 9 的 ASCII 码与非压缩 BCD 码的互相转换 解答 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 mov cl,3 shl ax,cl add ax,bx ;shl bx,1 add ax,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,4 again:shr dx,1 ;实现逻辑右移 ;采用“sar dx,1,那么实现算术右移 rcr ax,1 dec cl jnz again 习题 2.14AL=F7H表示有符号数-9,分别编写用 SAR 和 IDIV 指令实现的除以 2 的程序段,并说明各自执行后,所得的商是什么?解答 1用 sar 编写 mov al,0f7h ;-9 送 AL 1111 1001 sar al,1 ;结果:AL=1111 1100B=0FBH 即-5 2用 idiv 编写 mov al,0f7h ;-9 送 al cbw ;字节符号扩展位字 mov bl,2 ;注意除数不可为立即数 idiv bl ;结果:商为 al=fch (-4)欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!;余数:ah=ffh(-1)结论:符号数的除法用 idiv 准确。习题 2.15数据段 500h 600h 处存放了一个字符串,说明以下程序段执行后的结果:mov si,600h mov di,601h mov ax,ds mov es,ax mov cx,256 std rep movsb 解答 习题 2.16说明以下程序段的功能 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。习题 2.17指令指针 IP 是通用存放器还是专用存放器?有指令能够直接它赋值吗?哪类指令的执行会改变它的值?解答 指令指针 IP 不是通用存放器,不可直接赋值,属于专用存放器。有且仅有循环、转移、子程序调用和返回、中断类等指令可以改变它的值。习题 2.18控制转移类指令中有哪三种寻址方式?解答 控制转移类指令的寻址方式:相对寻址、直接寻址方式和间接寻址方式又可以分成存放器和存储器间接寻址。习题 2.19什么是短转移 short jump、近转移 near jump 和远转移 far jump?什么是段内转移和段间转移?8086 有哪些指令可以实现段间转移?解答 短转移:指段内128127 之间的转移,位移量用一个字节表示 近转移:指段内32K 之间的转移,位移量用一个字表示 远转移:指段间 1MB 范围的转移 段内转移:指在同一个代码段内的转移,可以是短转移或者近转移 段间转移:指转移到另外一个代码段,就是远转移 8086/8088CPU 的 JMP、CALL 和 INT n 指令可以实现段间转移 习题 2.208086 的条件转移指令的转移范围有多大?实际编程时,你如何处理超出范围的条件转移?解答 8086 的条件转移的转移范围:在当前指令地址的+127-128 之内。如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围外的目标地址。习题 2.21假设 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=2450H 习题 2.22判断以下程序段跳转的条件 1 xor ax,1e1eh je equal 2test al,10000001b jnz there 3cmp cx,64h jb there 解答 1AX1e1eh异或后为 0 2AL 的 D0 或 D7 至少有一位为 1 3CX无符号数 64h 习题 2.23设置 CX=0,那么 LOOP 指令将循环多少次?例如:mov cx,0 delay:loop delay 解答 216 次。习题 2.24假设 AX 和 SI 存放的是有符号数,DX 和 DI 存放的是无符号数,请用比较指令和条件转移指令实现以下判断:1假设 DX DI,转到 above 执行;2假设 AX SI,转到 greater 执行;3假设 CX=0,转到 zero 执行;4假设 AXSI 产生溢出,转到 overflow 执行;5假设 SIAX,转到 less_eq 执行;6假设 DIDX,转到 below_eq 执行。解答 1假设 DX DI,转到 above 执行 cmp dx,di ja above ;jnbe above 2假设 AX SI,转到 greater 执行 cmp ax,si jg greater ;jnle greater 3假设 CX=0,转到 zero 执行 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!cmp cx,0 jz zero ;jcxz zero 4假设 AXSI 产生溢出,转到 overflow 执行;cmp ax,si jo overflow 5假设 SIAX,转到 less_eq 执行;cmp si,ax ;cmp ax,si jle less_eq ;jge less_eq 6假设 DIDX,转到 below_eq 执行。cmp di,dx ;cmp dx,di jbe below_eq ;jae below_eq 习题 2.25有一个首地址为 array 的 20 个字的数组,说明以下程序段的功能。mov cx,20 mov ax,0 mov si,ax sum_loop:add ax,arraysi add si,2 loop sum_loop mov total,ax 解答 将首地址为 array 得 20 个字的数组求和,并将结果存入 total 单元中。习题 2.26按照以下要求,编写相应的程序段:1起始地址为 string 的主存单元中存放有一个字符串长度大于 6,把该字符串中的第1 个和第 6 个字符字节量传送给 DX 存放器。2 从主存 buffer 开始的 4 个字节中保存了 4 个非压缩 BCD 码,现按低 高 地址对低 高位的原那么,将它们合并到 DX 中。3编写一个程序段,在 DX 高 4 位全为 0 时,使 AX=0;否那么使 AX=-1。4有两个 64 位数值,按“小端方式存放在两个缓冲区 buffer1 和 buffer2 中,编写程序段完成 buffer1buffer2 功能。5假设从 B800h:0 开始存放有 100 个 16 位无符号数,编程求它们的和,并把 32 位的和保存在 DX.AX 中。6字符串 string 包含有 32KB 内容,将其中的$符号替换成空格。7有一个 100 个字节元素的数组,其首地址为 array,将每个元素减 1不考虑溢出存于原处。8统计以$结尾的字符串 srting 的字符个数。解答 1解答:mov si,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 寄.inc si mov al,buffersi ;第三字节 inc si mov ah,buffersi ;第四字节 mov cl,4 shl ah,cl ;BCD 码移到高半字节 or al,ah ;组合成压缩 BCD 码 mov dh,al ;存入 dh 寄.3解答:test dx,0f000h ;test dh,0f0h jz next ;jnz next mov ax,-1 ;mov ax,0 jmp again next:mov ax,0 ;mov ax,0ffffh again:.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 ;段地址 xor si,si ;地址偏移量 si=0 xor dx,dx ;和的高字 dx=0 mov cx,99 ;加的次数 mov ax,si ;第一个数 again:inc 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 again:cmp byte ptr si,$;$24h jnz next ;不要采用 jz 进行分支 mov byte ptr si,;20h next:inc si loop again ;dec cx ;jnz again 6解答 2:使用串操作指令 mov di,offset string mov al,$mov cx,8000h cld again:scasb jnz next mov byte ptr es:di-1,next:loop again 7解答 1:mov si,offset array mov cx,100 again:dec byte ptr si inc si loop again 7解答 2:xor si,si ;si-0 mov cx,100 ;循环次数 again:dec arraysi inc si loop again 7解答 3:mov si,offset array mov di,si mov ax,ds mov es,ax mov cx,100 cld again:lodsb dec al stosb loop again 8解答:xor si,si ;si-0 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!coun:cmp stringsi,$je done inc si jmp coun done:.习题 2.27对下面要求,分别给出 3 种方法,每种方法只用一条指令。1使 CF=0 2使 AX=0 3同时使 AX=0 和 CF=0 解答 1解答:clc and ax,ax or ax,ax 2解答:xor ax,ax and ax,0 mov ax,0 3解答:and ax,0 xor ax,ax sub ax,ax 习题 2.28参照本习题的示意图,分析调用序列,画出每次调用及返回时的堆栈状态。其中 CALL 前是该指令所在的逻辑地址;另外,段内直接调用指令的机器代码的字节数为 3,段间直接调用指令那么为 5 个字节。解答 主程序转子 suba 时段内调用:断点 1 为 2000h:0400h+3,转子是只将 IP 压栈。suba 转子 subb 时段间调用:断点 2 为 2000h:0840h+5,转子时须将 cs 段地址和 IP 压栈 suba 转子 subc 时段内调用:断点 3 为 2000h:0c021h+3,转子是只将 IP 压栈。注:压栈时先修改 sp 再压入断点,弹栈时先弹出断点再修改 sp。习题 2.29AX、BX 存放的是 4 位压缩 BCD 表示的十进制数,请说明如下子程序的功能和出口参数。add al,bl daa xchg al,ah adc al,bh daa xchg al,ah ret 解答 压缩 BCD 码加法:AXAXBX 出口参数:AXBCD 码和 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 2.30AAD 指令是用于除法指令之前,进行非压缩 BCD 码调整的。实际上,处理器的调整过程是:ALAH10AL,AH0。如果指令系统没有 AAD 指令,请用一个子程序完成这个调整工作。解答 shl ah,1 ;ah=2*a (设原 ah=a)mov dl,ah ;dl=2*a mov cl,2 ;设定移位次数 shl ah,cl ;ah=8*a add ah,dl ;ah=10*a add al,ah ;al=10*a+al xor ah,ah ;清零 ah int 3 ;返回 DOS 注意:入口:AX 中存放有“和两非压缩 BCD 码 出口:AL 中 已为调整后的二进制数 习题 2.31解释如下有关中断的概念:1 内部中断和外部中断 2 单步中断和断点中断 3 除法错中断和溢出中断 4 中断向量号和中断向量表 解答 1内部中断是由于 8086CPU 内部执行程序引起的程序中断;外部中断是来自 8086CPU之外的原因引起的程序中断;2单步中断是假设单步标志 TF 为 1,那么在每条指令执行结束后产生的中断;断点中断是供调试程序使用的,它的中断类型号为 3 通常调试程序时,把程序按程序的任务分成几段,然后,每段设一个段点;3除法错中断是在执行除法指令时,假设除数为 0 或商超过了存放器所能表达的范围产生的中断;溢出中断是在执行溢出中断指令 INTO 时,假设溢出标志 OF 为 1 时产生的中断;4 中断向量号是 中断类型号;中断向量表是中断向量号与它所对应的中断效劳程序起始地址的转换表。习题 2.32试比较 INT n 和段间 CALL 指令、IRET 和段间 RET 指令的功能。解答 INT n 响应中断时,除象 CALL 保护断点外,还应保护 FR;段间 CALL 指令用在主程序中实现子程序的调用。IRET 返回时,除象 RET 恢复断点外,还应恢复 FR;子程序执行完成后,应返回主程序中继续执行,这一功能由 RET 指令完成。习题 2.33什么是系统功能调用?汇编语言中,它的一般格式是怎样的?解答 系统功能调用是用户在程序一级请示操作系统效劳的一种手段,它不是一条简单的硬指令,而是带有一定功能号的“访指令,它的功能并非由硬件直接提供,而是由操作系统操作系统中的一段程序完成的,即由软件方法实现的 汇编语言中,它的一般格式是分如下四步进行:欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!1在 AH 存放器置系统功能调用号;2在指定的存放器中设置 入口参数;3用 INT21H(或 ROMBIOS 的中断向量号)指令执行功能调用;4据出口参数分析功能调用运行情况。习题 2.34补充例 2.40,当有溢出时显示“Error!Overflow!,无溢出时显示“OK。解答 okmsg db OK,$errmsg db Error!Overflow!,$mov ax,X sub ax,Y jo overflow mov dx,offset okmsg jmp next overflow:mov dx,errmsg next:mov ah,9 int 21h 错误解答:mov ax,X sub ax,Y jo overflow mov dx,offset okmsg okmsg db OK,$mov dx,errmsg ;错误 1:数据定义在代码中 mov ah,9 int 21h overflow:errmsg db Error!Overflow!,$mov dx,errmsg ;错误 2:缺少 JMP 指令 mov ah,9 int 21h 习题 2.35补充例 2.42,显示“1的个数;注意首先将个数转换为 ASCII 码。解答 and al,7fh ;使 d7=0 mov dl,al ;转存于 dl jnp next ;奇数个 1 转 or al,80h ;偶数个 1 使 d7=1 next:xor bl,bl ;纪录 1 的个数 dl=0 mov cx,8 ;移位次数 again:shl dl,1 ;逻辑左移 1 次 jnc desp ;如 cf=0 转 inc bl ;否那么 cf=1 个数加 1 desp:loop again ;cx=cx-1 如 cx 不等于 0,循环 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!or bl,30h ;个数变为 ASCII 码 mov ah,02h ;在 CRT 上显示个数 mov dl,bl int 21h ret 习题 2.36先提示输入数字“Input Number:0 9,然后在下一行显示输入的数字,结束;如果不是键入了 0 9 数字,就提示错误“Error!,继续等待输入数字。解答 ;数据段 str1 db Input Number:09:,0dh,0ah,$str2 db Error!,0dh,0ah,$;代码段 mov ah,09h ;显示 str1 字符串 mov dx,offset str1 int 21h getkey:mov ah,1 ;调用 DOS 功能 int 21h cmp al,0 jb error ;小于 0,出错处理 cmp al,9 ja error ;大于 9,出错处理 mov ah,02h ;调用 DOS 显示字符功能,显示该数字 mov dl,al int 21h .;终止程序执行,返回 DOS error:mov ah,09h ;出错,调用 DOS 功能显示 str2 字符串 mov dx,offset str2 int 21h jmp getkey ;返回按键 习题 2.37从键盘输入一个字符串不超过 255 个,将其中的小写字母转换成大写字母,然后按原来的顺序在屏幕上显示。解答 思路:参考 P67 例 2.52 用 0ah 号 DOS 系统功能调用,从键盘输入一个字符串,然后从键盘缓冲区逐个取字符,在“a与“z之间的字符为小写字母,需要转换为大写字母 减去 20h,其他不变。.model small .stack .data array db 255 db 0 array1 db 255 dup($)欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!array2 db 0dh,0ah,$.code .startup mov ah,0ah ;键盘输入字符串 mov dx,offset array int 21h mov dx,offset array2 ;回车换行 mov ah,09h int 21h mov bx,offset array1 again:mov al,bx cmp al,$jz done cmp al,a ;小于 a 和大于 z 的字符不是小写字母 jb next cmp al,z ja next sub al,20h ;在 a 和 z 之间的字符才是小写字母,转换为大写 mov bx,al ;保存到原位置 next:inc bx jmp again done:mov dx,offset array1 mov ah,09h int 21h .exit 0 end 习题 2.38 指令对状态标志的作用可以分成多种情况,例如无影响、无定义、按结果影响、特别说明的影响等,你能区别这些情况吗?分别用具体的指令来说明。解答 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 2.398086 指令系统分成哪 6 个功能组?各组主要包含什么指令,举例说明。解答 8086 指令系统分成的 6 个功能组是 1数据传送类令:通用数据传送指令如传送指令 MOV、交换指令 XCHG、换码指令 XLAT 堆栈操作指令如进栈指令 PUSH 出栈指令 POP 标志传送指令如标志存放器传送;标志位操作 地址传送指令如有效地址传送指令 LEA、指针传送指令 LDS 指针传送指令 LES 输入输出指令如输入指令 IN、输出指令 OUT 2算术运算指令 加法指令如加法指令 ADD、带进位加法指令 ADC、增量指令 INC 减法指令如减法指令 SUB、带借位指令 SBB、减量指令 DEC、求补指令 NEG、比较指令CMP 乘法指令如无符号乘法指令 MUL、有符号乘法指令 IMUL 除法指令如无符号数除法指令 DIV、有符号数除法指令 IDIV 符号扩展指令如字节转换字指令 CBW、字转换字节指令 CWD 十进制调整指令如压缩 BCD 码调整指令、非压缩 BCD 码调整指令 3位操作类指令 逻辑运算指令如逻辑指令 AND、逻辑或指令 OR、逻辑异或指令 XOR、逻辑非指令 NOT、测试指令 TEST 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!移位指令如逻辑移位指令 SHL 和 SHR、算术移位指令 SAL 和 SAR 循环移位指令如不带移位指令 XOL 和 ROR、带移位指令 RCL 和 RCR 4控制转移类指令 无条件转移指令 JMP 条件转移指令如判断单个标志状态 JZ/JE、JNZ/JNE、JS/JNS、JP/JPE、JNP/JPO、JC/JB、JNC/JNB/JAE,用于比较无符号数上下 JB(JNAE)、JNB(JAE)、JBE(JNA)、JNBE(JA),用于比较有符号数大小 JL(JNGE)、JNL(JGE)、JLE(JNG)、JNLE(JG)循环指令 LOOP 子程序指令如子程序调用指令 CALL、子程序返回指令 RET 中断指令如 INT N 5串操作类指令 串传送指令 MOVS 串存储指令 STOS 串读取指令 LODS 串比较指令 CMPS 串扫描指令 SCAS 重复前缀指令 REP;6处理机控制类指令 空操作指令 NOP 段超越前缀指令 SEG 封锁前缀指令 LOCK 暂停指令 HLT 交权指令 ESC 等待指令 WAIT。习题 2.40总结 8086 指令系统所采用的各种寻址方式,包括一般的数据寻址、外设数据寻址、堆栈数据寻址、串操作数据寻址、转移指令目的地址的寻址等,并举例说明。解答 1.一般的数据寻址 立即数寻址方式如:mov al,05h 存放器寻址方式如:mov bx,ax 存储器寻址方式 1直接寻址方式如:mov ax,2000h 2存放器间接寻址方式如:mov ax,es:2000h 3存放器相对寻址方式如:mov ax,di+06h 4基址变址寻址方式如:mov ax,bx+si 5相对基址变址寻址方式如:mov ax,bx+si+06h 2.外设数据寻址 输入指令 IN,如:in al,21h in ax,dx 输出指令 OUT,如:out dx,al 3.堆栈数据寻址 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!进栈指令 PUSH,如:PUSH 2000H 出栈指令 POP,如:POP 2000H 4.串操作数据寻址 5.转移指令目的地址的寻址 直接寻址、间接寻址、相对寻址