新版汇编语言程序设计课后答案 下载本文

内容发布更新时间 : 2024/7/3 0:06:57星期一 下面是文章的全部内容请认真阅读。

第2章(03) 2.12;

指令 注释 执行结果 CF OF SF ZF PF

mov si,ax si=ax si=0008h - - - - -

shl si,1 si=2*ax si=0010h 0 0 0 0 0

add si,ax si=3*ax si=0018h 0 0 0 0 1

mov dx,bx dx=bx dx=0010h - - - - -

mov cl,03h cl=03h - - - - -

shl dx,cl dx=8*bx dx=0080h 0 u 0 0 0

sub dx,bx dx=7*bx dx=0070h 0 0 0 0 0

add dx,si dx=7*bx+3*ax dx=0088h 0 0 0 0 1

注意:

1. 左移N次相当于乘于2的N次方,右左移N次相当于除乘于2的N次方。

2. 移位指令根据是否移入“1”到CF,设置CF,根据移位后的结果影响SF,ZF,PF。根据最高符号位是否改变设置OF,如改变 OF=1. 3. ‘ u ’表示无定义,‘ - ’表示无影响。 2.13; (1)

;不考虑进位mov bl,al mov cl,3 shl al,cl

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)

数字0~9的ASCII码是:30h~39h 非压缩BCD码的0~9是:00h~09h 方法一:

and al,0fh ;实现ASCII到非压缩BCD码的转换 or al,30h ;实现非压缩BCD码到ASCII的转换 方法二:

xor al,30h ;求反D5D4位,其他不变

;即高4位为3,则变为0;高4位为0,则变为3 mov cl,4

again: shr dx,1 ;实现逻辑右移 ;采用“sar dx,1”,则实现算术右移 rcr ax,1 dec cl jnz again

2.14; (1)用sar编写 mov al,0f7h ;-9送al

sar al,1 ;结果:al=0fbh 即-5 (2)用idiv编写

mov al,0f7h ;-9送al

cbw ;字节符号扩展位字

mov bl,2 ;注意除数不可为立即数 idiv bl ;结果:商为al=fch (-4) ;余数为ah=ffh (-1) 结论:符号数的除法用idiv 准确 2.19;

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

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

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

第2章(04)

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

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

2.21; (1)JMP Bx ;转移的有效地址EA=BX=1256h

(2)JMP tABLE[Bx] ;转移的有效地址EA=[ds:20a1h+1256h]=[232f7]=3280h (3)JMP [Bx][si] ;转移的有效地址EA=[ds:1256h+528fh]=264e5h=2450h 2.22; (1) xor ax,1e1eh je equal

;AX=1e1eh(异或后为0) (2)test al,10000001b jnz there

;AL的D0或D7至少有一位为1 (3) cmp cx,64h jb there

;CX(无符号数)< 64h 2.23;

mov cx,0 不循环,因为一进入循环就判 cx=0? 如cx=0 就退出循环 delay:loop delay

2.24; (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 jcxz zero jz zero

(4)若AX-SI产生溢出,转到overflow执行; cmp ax,di jo overflow

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

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

2.25; 答:将首地址为array得20个字的数组求和,并将结果存入 total 单元中。