汇编语言程序设计(第四版)第2章[课后答案] 联系客服

发布时间 : 星期五 文章汇编语言程序设计(第四版)第2章[课后答案]更新完毕开始阅读1971bc600a4e767f5acfa1c7aa00b52acfc79ce2

.

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.14〕已知AL = 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〕指令指针IP是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指令的执行会改变它的值?

〔解答〕

指令指针IP不是通用寄存器,不可直接赋值,属于专用寄存器。有且仅有循环、转移、子程序调用和返回、中断类等指令可以改变它的值。

〔习题2.16〕控制转移类指令中有哪三种寻址方式?

〔解答〕

- 9 -页

.

控制转移类指令的寻址方式:相对寻址、直接寻址方式和间接寻址方式(又可以分成寄存器和存储器间接寻址)。

〔习题2.17〕什么是短转移short jump、近转移near jump和远转移far jump?什么是段内转移和段间转移?8086有哪些指令可以实现段间转移?

〔解答〕

短转移:指段内-128~127之间的转移,位移量用一个字节表示 近转移:指段内±32K之间的转移,位移量用一个字表示 远转移:指段间1MB范围的转移

段内转移:指在同一个代码段内的转移,可以是短转移或者近转移 段间转移:指转移到另外一个代码段,就是远转移

8086/8088CPU的JMP、CALL和INT n指令可以实现段间转移

〔习题2.18〕8086的条件转移指令的转移范围有多大?实际编程时,你如何处理超出范围的条件转移?

〔解答〕

8086的条件转移的转移范围:在当前指令地址的 +127~-128之内。

如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围外的目标地址。

〔习题2.19〕假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?

(1) JMP BX

(2) JMP TABLE[BX] (3) JMP [BX][SI] 〔解答〕

(1)转移的有效地址EA= BX=1256H

(2)转移的有效地址EA= [DS:20A1H+1256H]=[232F7]=3280H (3)转移的有效地址EA= [DS:1256H+528FH]=264E5H=2450H 〔习题2.20〕判断下列程序段跳转的条件

(1) xor ax,1e1eh je equal (2)test al,10000001b jnz there (3)cmp cx,64h jb there 〔解答〕

- 10 -页

.

(1)AX=1e1eh(异或后为0) (2)AL的D0或D7至少有一位为1 (3)CX(无符号数)< 64h

〔习题2.21〕设置CX = 0,则LOOP指令将循环多少次?例如:

mov cx,0 delay: loop delay 〔解答〕 216次。

〔习题2.22〕假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:

(1)若DX > DI,转到above执行; (2)若AX > SI,转到greater执行; (3)若CX = 0,转到zero执行;

(4)若AX-SI产生溢出,转到overflow执行; (5)若SI≤AX,转到less_eq执行; (6)若DI≤DX,转到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)若AX-SI产生溢出,转到overflow执行; cmp ax,si jo overflow

(5)若SI≤AX,转到less_eq执行; cmp si,ax ; cmp ax,si

- 11 -页

.

jle less_eq ; jge less_eq (6)若DI≤DX,转到below_eq执行。 cmp di,dx ; cmp dx,di jbe below_eq ; jae below_eq

〔习题2.23〕有一个首地址为array的20个字的数组,说明下列程序段的功能。

mov cx,20 mov ax,0 mov si,ax

sum_loop: add ax,array[si] add si,2 loop sum_loop mov total,ax 〔解答〕

将首地址为array得20个字的数组求和,并将结果存入 total 单元中。 〔习题2.24〕按照下列要求,编写相应的程序段:

(1)起始地址为string的主存单元中存放有一个字符串(长度大于6),把该字符串中的第1个和第6个字符(字节量)传送给DX寄存器。

(2)从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低(高)地址对低(高)位的原则,将它们合并到DX中。

(3)编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1。

(4)有两个64位数值,按“小端方式”存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1-buffer2功能。

(5)假设从B800h : 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在DX.AX中。

(6)已知字符串string包含有32KB内容,将其中的’$’符号替换成空格。

(7)有一个100个字节元素的数组,其首地址为array,将每个元素减1(不考虑溢出)存于原处。 (8)统计以 ’$’ 结尾的字符串srting的字符个数。 〔解答〕 (1)解答: mov si,0

mov dl,string[si] ;第1个字符送dl寄存器:mov dl,stirng[0] mov si,5

- 12 -页