汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx

上传人:b****5 文档编号:16695587 上传时间:2022-11-25 格式:DOCX 页数:19 大小:26.01KB
下载 相关 举报
汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx_第1页
第1页 / 共19页
汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx_第2页
第2页 / 共19页
汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx_第3页
第3页 / 共19页
汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx_第4页
第4页 / 共19页
汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx_第5页
第5页 / 共19页
点击查看更多>>
下载资源
资源描述

汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx

《汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx(19页珍藏版)》请在冰豆网上搜索。

汇编语言程序设计第四版第2章课后答案Word格式文档下载.docx

(6)目的操作数应为[SI]

(7)源操作数应为[BX+DI] 

(8)立即数不能作目的操作数

〔习题2.3〕已知数字0~9对应的格雷码依次为:

18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址(设为200H)的连续区域中。

请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。

leabx,table

moval,8

xlat

leabx,table 

获取table的首地址,BX=200H

moval,8 

 

传送欲转换的数字,AL=8

xlat 

转换为格雷码,AL=12H 

P35

〔习题2.4〕什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?

堆栈是一种按“先进后出”原则存取数据的存储区域,位于堆栈段中,使用SS段寄存器记录其段地址;

它的工作原则是先进后出;

堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。

〔习题2.5〕已知SS=2200H、SP=00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?

movax,8057h

pushax

movax,0f79h 

popbx

pop[bx]

movax,0f79h

popbx 

bx=0f79h

pop[bx] 

DS:

[0f79h]=8057h

〔习题2.6〕给出下列各条指令执行后AL值,以及CF、ZF、SF、OF和PF的状态:

moval,89h

addal,al

addal,9dh

cmpal,0bch

subal,al

decal

incal

moval,89h 

AL=89h 

CF 

ZF 

SF 

OF 

PF

addal,al 

AL=12h 

1

;

10001001

+10001001

100010010

addal,9dh 

AL=0afh 

00010010

+10011101

10101111

cmpal,0bch 

10101111

-10111100

*01000011

subal,al 

AL=00h 

decal 

AL=0ffh 

00000000

-00000001

*11111111

incal 

11111111

+00000001

〔习题2.7〕设X、Y、Z均为双字数据,分别存放在地址为X、X+2;

Y、Y+2;

Z、Z+2的存储单元中,它们的运算结果存入W单元。

阅读如下程序段,给出运算公式。

movax,X

movdx,X+2

addax,Y

adcdx,Y+2

addax,24

adcdx,0

subax,Z

sbbdx,Z+2

movW,ax

movW+2,dx

W=X+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中。

(1)ADDDX,BX

(2)ADDAL,[BX+SI]

(3)ADD[BX+0B2H],CX

(4)ADDWORDPTR[0520H],3412H

(5)ADDAL,0A0H

〔习题2.9〕设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。

movax,X 

ax=X

imulY 

DX.AX=X*Y

movcx,ax 

cx=X*Y的低16位

moxbx,dx 

bx=X*Y的高16位

movax,Z 

ax=Z

cwd

addcx,ax 

cx=Z的低16位+X*Y的低16位

adcbx,dx 

bx=Z的高16位+X*Y的高16位+低位进位

subcx,540 

cx=Z的低16位+X*Y的低16位-540

sbbbx,0 

bx=Z的高16位+X*Y的高16位+低位进位-低位借位

movax,V 

ax=V

subax,cx 

ax=V的低16位-(Z的低16位+X*Y的低16位-540)

sbbdx,bx 

dx=V的高16位-(Z的高16位+X*Y的高16位+低位进位-低位借位)-低位借位

idivX;

/X

[V-(X*Y+Z-540)]/X

AX存商,DX存余数

〔习题2.10〕指出下列指令的错误:

(1)xchg[si],30h

(2)popcs

(3)sub[si],[di]

(4)pushah

(5)adcax,ds

(6)add[si],80h

(7)inal,3fch

(8)outdx,ah

(1)xchg的操作数不能是立即数

(2)不应对CS直接赋值

(3)两个操作数不能都是存储单元

(4)堆栈的操作数不能是字节量

(5)adc的操作数不能是段寄存器

(6)没有确定是字节还是字操作

(7)in不支持超过FFH的直接寻址

(8)out只能以AL/AX为源操作数

〔习题2.11〕给出下列各条指令执行后的结果,以及状态标志CF、OF、SF、ZF、PF的状态。

movax,1470h

andax,ax

orax,ax

xorax,ax

notax

testax,0f0f0h

〔解答〕 

movax,1470h 

AX=1470HCF 

andax,ax 

AX=1470H0 

0

0001010001110000

orax,ax 

xorax,ax 

AX=0000H0 

notax 

AX=FFFFH0 

testax,0f0f0h 

注意:

MOV和NOT指令不影响标志位;

其他逻辑指令使CF=OF=0,根据结果影响其他标志位。

〔习题2.12〕假设例题2.34的程序段中,AX=08H,BX=10H,请说明每条指令执行后的结果和各个标志位的状态。

指令 

执行结果 

CFOFSFZFPF

movsi,ax 

SI=AX=0008H 

-

shlsi,1 

SI=2*AX=0010H 

addsi,ax 

SI=3*AX=0018H 

1

movdx,bx 

DX=BX=0010H 

1

movcl,03h 

CL=03H 

shldx,cl 

DX=8*BX=0080H 

0

subdx,bx 

DX=7*BX=0070H 

adddx,si 

DX=7*BX+3*AX=0088H 

逻辑左移N次相当于无符号整数乘以2的N次方,逻辑右移N次相当于无符号整数除以2的N次方。

移位指令根据移位的数据设置CF,根据移位后的结果影响SF,ZF,PF。

在进行一位移位时,根据最高符号位是否改变设置OF,如改变则OF=1。

另外,程序注释用“u”表示标志无定义(不确定),“-”表示无影响。

〔习题2.13〕编写程序段完成如下要求:

(1)用位操作指令实现AL(无符号数)乘以10

(2)用逻辑运算指令实现数字0~9的ASCII码与非压缩BCD码的互相转换

(3)把DX.AX中的双字右移4位

(1) 

不考虑进位 

movbl,al

movcl,3

shlal,cl 

*8

addal,bl 

shlbl,1 

addal,bl

考虑进位

xorah,ah

movbx,ax

shlax,cl

addax,bx 

shlbx,1

addax,bx

(2)数字0~9的ASCII码是:

30h~39h

非压缩BCD码的0~9是:

00h~09h

方法一:

andal,0fh 

实现ASCII到非压缩BCD码的转换

oral,30h 

实现非压缩BCD码到ASCII的转换

方法二:

xoral,30h 

求反D5D4位,其他不变

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

高4位为0,则变为3

(3) 

movcl,4

again:

shrdx,1 

实现逻辑右移

采用“sardx,1”,则实现算术右移

rcrax,1

deccl

jnzagain

〔习题2.14〕已知AL=F7H(表示有符号数-9),分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得的商是什么?

(1)用sar编写

moval,0f7h 

-9送AL11111001

saral,1 

结果:

AL=11111100B=0FBH 

即-5

(2)用idiv编写

-9送al

cbw 

字节符号扩展位字

movbl,2 

注意除数不可为立即数

idivbl 

商为al=fch 

(-4)

余数:

ah=ffh(-1)

结论:

符号数的除法用idiv准确。

〔习题2.15〕指令指针IP是通用寄存器还是专用寄存器?

有指令能够直接它赋值吗?

哪类指令的执行会改变它的值?

指令指针IP不是通用寄存器,不可直接赋值,属于专用寄存器。

有且仅有循环、转移、子程序调用和返回、中断类等指令可以改变它的值。

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

控制转移类指令的寻址方式:

相对寻址、直接寻址方式和间接寻址方式(又可以分成寄存器和存储器间接寻址)。

〔习题2.17〕什么是短转移shortjump、近转移nearjump和远转移farjump?

什么是段内转移和段间转移?

8086有哪些指令可以实现段间转移?

短转移:

指段内-128~127之间的转移,位移量用一个字节表示

近转移:

指段内±

32K之间的转移,位移量用一个字表示

远转移:

指段间1MB范围的转移

段内转移:

指在同一个代码段内的转移,可以是短转移或者近转移

段间转移:

指转移到另外一个代码段,就是远转移

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

〔习题2.18〕8086的条件转移指令的转移范围有多大?

实际编程时,你如何处理超出范围的条件转移?

8086的条件转移的转移范围:

在当前指令地址的+127~-128之内。

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

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

(1)JMPBX

(2)JMPTABLE[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)xorax,1e1eh

jeequal

(2)testal,10000001b

jnzthere

(3)cmpcx,64h

jbthere

(1)AX=1e1eh(异或后为0)

(2)AL的D0或D7至少有一位为1

(3)CX(无符号数)<64h

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

例如:

movcx,0

delay:

loopdelay

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执行。

DI,转到above执行

cmpdx,di

jaabove 

=jnbeabove

SI,转到greater执行

cmpax,si

jggreater 

=jnlegreater

(3)若CX=0,转到zero执行

cmpcx,0

jzzero 

=jcxzzero 

jooverflow

cmpsi,ax 

jleless_eq 

jgeless_eq

cmpdi,dx 

jbebelow_eq 

jaebelow_eq

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

movcx,20

movax,0

movsi,ax

sum_loop:

addax,array[si]

addsi,2

loopsum_loop

movtotal,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)假设从B8

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试认证 > 司法考试

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

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