汇编语言程序设计 习题2:微处理器指令系统学习资料.doc
PAGE
PAGE1
第2章微处理器指令系统(习题2)
2.8问题:
已知DS=2000H、BX=0100H、SI=0002H,存储单元[20100H]~[20103H]依次存放12H、34H、56H、78H,[21200H]~[21203H]依次存放2AH、4CH、B7H、65H,说明下列每条指令执行完后AX寄存器的内容,以及源操作数的寻址方式?
解答:
⑴movax,1200h ;AX=1200H,立即数寻址
⑵movax,bx ;AX=0100H,寄存器寻址
⑶movax,[1200h] ;AX=4C2AH,直接寻址
⑷movax,[bx] ;AX=3412H,寄存器间接寻址
⑸movax,[bx+1100h];AX=4C2AH,寄存器相对寻址
⑹movax,[bx+si] ;AX=7856H,基址变址寻址
⑺movax,[bx][si+1100h];AX=65B7H,相对基址变址寻址
2.11问题:
给出下列各条指令执行后AL值,以及CF、ZF、SF、OF和PF的状态:
解答:
moval,89h ;AL=89H CF ZF SF OF PF
addal,al ;AL=12H 1 0 0 1 1
addal,9dh ;AL=0AFH0 0 10 1
cmpal,0bch ;AL=0AFH1 0 1 0 1
subal,al ;AL=00H0 1 0 0 1
decal ;AL=0FFH0 0 1 0 1
incal ;AL=00H0 1 0 0 1
2.12问题:
请分别用一条汇编语言指令完成如下功能:
解答:
⑴把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器
adddx,bx
⑵用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中
addal,[bx+si]
⑶用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和CX寄存器的内容相加,并把结果送回存储器中
add[bx+0b2h],cx
⑷用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中
addwordptr[0520h],3412h
⑸把数0A0H与AL寄存器的内容相加,并把结果送回AL中
addal,0a0h
2.14问题:
给出下列各条指令执行后的结果,以及状态标志CF、OF、SF、ZF、PF的状态。
解答:
movax,1470h ;AX=1470H CF ZF SF OF PF
andax,ax ;AX=1470H 0 0 0 0 0
orax,ax ;AX=1470H 0 0 0 0 0
xorax,ax ;AX=0000H 0 1 0 0 1
notax ;AX=FFFFH 0 1 0 0 1
testax,0f0f0h
习题2.17
问题:
判断下列程序段跳转的条件
解答:
⑴ xorax,1e1eh
jeequal ;AX=1e1eh(异或后为0)
⑵ testal
jnzthere ;AL的D0或D7至少有一位为1
⑶ cmpcx,64h
jbthere ;CX(无符号数)<64h
2.20问题:
按照下列要求,编写相应的程序段。
解答:
⑴起始地址为string的主存单元中存放有一个字符串(长度大于6),把该字符串中的第1个和第6个字符(字节量)传送给DX寄存器。
movdl,string[0]
movdh,string[5]
⑵有两个32位数值,按“小端方式”存放在两个缓冲区buffer1和buffer2中,编写程序段完成DX.AX←buffer1-buffer2功能。
movax,wordptrbuffer1
subax,wordptrbuffer2
;先减低16位
movdx,wordptrbuffer1+2
sbbdx,wordptrbuffer2+2
;后减高16位,需减低16位的借位
⑶编写一个程序段,在DX高4位全为0时,使AX=0;否则使AX=-1。
testdx,0f000h
jznext
movax,-1
jmpdone
next: movax,0
done: …
⑷把DX.AX中的双字右移4位
答:
movcx,4
again: