新版汇编语言程序设计课后答案文档格式.docx
- 文档编号:16257790
- 上传时间:2022-11-22
- 格式:DOCX
- 页数:11
- 大小:25.98KB
新版汇编语言程序设计课后答案文档格式.docx
《新版汇编语言程序设计课后答案文档格式.docx》由会员分享,可在线阅读,更多相关《新版汇编语言程序设计课后答案文档格式.docx(11页珍藏版)》请在冰豆网上搜索。
FFH 0H 5EH EFH2EH 10H 1FH ABH〔解答〕
FFH 11111111B 255D
0H 0B 0D
5EH 1011110B 94D
EFH 11101111B 239D
2EH 101110B 46D
10H 10000B 16D
1FH 11111B
ABH 10101011B
〔习题〕
将下列十进制数转换为BCD码表示
12 24
128 255
12 00010010
24 00100100
68 01101000
127 000100100111
128 000100101000
255 001001010101
1234 0001001000110100
2458 0010010001011000
将下列BCD码转换为十进制数
68 7)1234 31D171D1278)2458 10010001 10001001 00110110 10010000
00001000 10010111 10000001 00000010
91
89
36 90
08 97
81 02
〔习题〕将下列十进制数分别用8位二进制数的原码、反码和补码表示0 -127 127
126 -126 -128
0+0000000000000000000000000
-0100000001111111100000000
-127 111111111000000010000001
127 011111110111111101111111
-57 10101111 1101000011010001
126 01111110 0111111001111110
-126 11111110 1000000110000010
-578)68
-128 10000000
68 01000100 0100010001000100
〔习题〕完成下列二进制数的运算
1011+10011011-10011011×
100110111000÷
1001
1011∧10011011∨1001~1011 10111001
1011+1001=10100
1011-1001=0010
1011×
1001=1100011
10111000÷
1001=10100,余数1000
1011∧1001=1001
1011∨1001=1011
~1011=0100
(8)10111001=0010(代表异或)
〔习题〕数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?
ASCII码为0dh、0ah对应的是什么字符?
数码0~9:
30H~39H
大写字母A~Z:
41H~5AH
小写字母a~z:
61H~7AH
ASCII码为0dh、0ah分别对应回车和换行控制字符。
〔习题〕计算机中有一个“01100001”编码,如果把它认为是无符号数,它是十进制什么数?
如果认为它是BCD码,则表示什么数?
又如果它是某个ASCII码,则代表哪个字符?
十进制无符号数:
01100001B=61H=97
BCD码:
61
ASCII码:
a
〔习题〕简述Intel80x86系列微处理器在指令集方面的发展。
1978年Intel,正式推出了16位8086CPU,1979年Intel推出了准16位微处理器8088,随后,Intel推出了80186/80188,80186/80188指令系统比8086指令系统新增了若干条实用的指令,涉及堆栈操作、移位指令、过程指令和边界检测及乘法指令,1982年Intel推出80286CPU,80286指令系统包括全部80186指令及新增的保护指令15条,其中有些保护方式在实方式下也可以使用,1985年,Intel80x86推出微处理器地进入第三代80386CPU,80386指令系统在兼容原来16位指令系统的基础上,全面升级为32位,还新增了有关位操作、条件设置指令以及控制、调试和测试寄存器的传送指令等,1989年,Intel推出了80486CPU,80486将浮点处理单元FPU集成进来,还采用了精简指令集计算机技术RISC和指令流水线方式,还新增了用于多处理器和内部Cache操作的6条指令,1993年Intel制成了俗称586的微处理器,取名Pentium。
Pentium仍为32位结构,地址总线为32位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium新增了一条8字节比较交换指令和一条处理器识别指令,以及4条系统专用指令,1996年推出了MMXPentium,新增了57条多媒休指令,1995年Intel推出PentiumPro新增了3条指令,1999年推出了PentiumⅢ新增了70条SSE指令,20XX年推出的Pentium4新增了76条SSE2指令
〔习题〕什么是DOS和ROM-BIOS?
DOS是DisketteOperatingsystem的缩写,意思是磁盘操作系统,DOS主要是面向磁盘的系统软件,说得简单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层“外壳”,是1981~1995年的个人电脑上使用的一种主要的操作系统。
BIOS即基本输入输出系统,通常是固化在只读存储器中,所以又称为ROM-BIOS。
它直接对计算机系统中的输入、输出设备进行设备级、硬件级的控制,是连接软件程序和硬件设备之间的枢纽。
ROM-BIOS是计算机系统中用来提供最低级、最直接的硬件控制的程序。
〔习题〕简述PC机最低1MB主存空间的使用情况。
基本RAM区(00000H—9FFFFH)该区共640KB,DOS进行管理。
在这个区域中操作系统要占用掉一部分低地址空间,其它则向用户程序开放。
保留区RAM该区为系统安排的“显示缓冲存储区”,共126KB,是显卡上的芯片提供支持,用于存放屏幕显示信息。
但这部分地址空间实际上并没有全部使用。
扩展区ROM该区128KB,接口卡上的芯片提供支持,用于为系统不直接支
〔习题〕已知数字0~9对应的格雷码依次为:
18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址的连续区域中。
请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。
leabx,table moval,8 xlat〔解答〕
leabx,table ;
获取table的首地址,BX=200H moval,8 ;
传送欲转换的数字,AL=8 xlat ;
转换为格雷码,AL=12HP35
〔习题〕什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?
堆栈是一种按“先进后出”原则存取数据的存储区域,位于堆栈段中,使用SS段寄存器记录其段地址;
它的工作原则是先进后出;
堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。
〔习题〕已知SS=2200H、SP=00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?
movax,8057h pushax movax,0f79h pushax popbx pop[bx]〔解答〕
movax,8057h pushax movax,0f79h pushax
popbx ;
bx=0f79h
pop[bx] ;
DS:
[0f79h]=8057h
〔习题〕给出下列各条指令执行后AL值,以及CF、ZF、SF、OF和PF的状态:
moval,89h addal,al addal,9dh cmpal,0bch subal,al decal incal〔解答〕
moval,89h ;
AL=89hCFZFSFOFPFaddal,al ;
AL=12h10011;
10001001+10001001100010010
addal,9dh ;
AL=0afh00101;
00010010
+1001110110101111
cmpal,0bch ;
AL=0afh10101;
10101111-10111100*01000011
subal,al ;
AL=00h01001
decal ;
AL=0ffh00101;
00000000-00000001*11111111
incal ;
AL=00h01001;
11111111+00000001*11111111
〔习题〕设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
〔习题〕请分别用一条汇编语言指令完成如下功能:
把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器。
用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中。
用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和CX寄存器的内容相加,并把结果送回存储器中。
用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中。
把数0A0H与AL寄存器的内容相加,并把结果送回AL中。
ADDDX,BXADDAL,[BX+SI]ADD[BX+0B2H],CX
ADDWORDPTR[0520H],3412HADDAL,0A0H
〔习题〕设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。
movax,X ;
ax=X imulY ;
=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 cwd
subax,cx ;
ax=V的低16位-
sbbdx,bx ;
dx=V的高16位--低位借位
idivX;
/X〔解答〕
[V-(X*Y+Z-540)]/X AX存商,DX存余数
〔习题〕指出下列指令的错误:
xchg[si],30hpopcssub[si],[di]pushahadcax,dsadd[si],80hinal,3fchoutdx,ah〔解答〕
xchg的操作数不能是立即数不应对CS直接赋值
两个操作数不能都是存储单元堆栈的操作数不能是字节量adc的操作数不能是段寄存器没有确定是字节还是字操作in不支持超过FFH的直接寻址out只能以AL/AX为源操作数
〔习题〕给出下列各条指令执行后的结果,以及状态标志CF、OF、SF、ZF、PF的状态。
movax,1470h andax,ax orax,ax xorax,ax notax testax,0f0f0h
〔解答〕
movax,1470h ;
AX=1470HCFZFSFOFPF
andax,ax ;
AX=1470H00000 ;
0001010001110000
orax,ax ;
AX=1470H00000 xorax,ax ;
AX=0000H01001 notax ;
AX=FFFFH01001 testax,0f0f0h ;
AX=FFFFH00101
注意:
MOV和NOT指令不影响标志位;
其他逻辑指令使CF=OF=0,根据结果影响其他标志位。
〔习题〕假设例题的程序段中,AX=08H,BX=10H,请说明每条指令执行后的结果和各个标志位的状态。
指令 ;
执行结果 CFOFSFZFPF movsi,ax ;
SI=AX=0008H - - -- - shlsi,1 ;
SI=2*AX=0010H 0 0 0 0 0
addsi,ax ;
SI=3*AX=0018H 0 0 0 0 1 movdx,bx;
DX=BX=0010H 0 0 0 0 1 movcl,03h;
CL=03H 0 0 0 0 1 shldx,cl ;
DX=8*BX=0080H 0 u 0 0 0 subdx,bx ;
DX=7*BX=0070H 0 0 0 0 0 adddx,si ;
DX=7*BX+3*AX=0088H0 0 0 0 1
逻辑左移N次相当于无符号整数乘以2的N次方,逻辑右移N次相当于无符号整数除以2的N次方。
移位指令根据移位的数据设置CF,根据移位后的结果影响SF,ZF,PF。
在进行一位移位时,根据最高符号位是否改变设置OF,如改变则OF=1。
另外,程序注释用“u”表示标志无定义,“-”表示无影响。
〔习题〕编写程序段完成如下要求:
用位操作指令实现AL乘以10
用逻辑运算指令实现数字0~9的ASCII码与非压缩BCD码的互相转换把中的双字右移4位〔解答〕
;
不考虑进位 movbl,al movcl,3
shlal,cl ;
*8 addal,bl ;
shlbl,1 addal,bl ;
考虑进位 xorah,ah movbx,ax movcl,3 shlax,cl
addax,bx ;
shlbx,1 addax,bx
数字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 movcl,4
again:
shrdx,1 ;
实现逻辑右移
;
采用“sardx,1”,则实现算术右移 rcrax,1 deccl jnzagain
〔习题〕已知AL=F7H,分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得的商是什么?
〔解答〕用sar编写
moval,0f7h ;
-9送AL11111001
saral,1 ;
结果:
AL=11111100B=0FBH即-5用idiv编写
-9送al cbw ;
字节符号扩展位字 movbl,2 ;
注意除数不可为立即数 idivbl ;
商为al=fch(-4) ;
余数:
ah=ffh(-1)结论:
符号数的除法用idiv准确。
〔习题〕已知数据段500h~600h处存放了一个字符串,说明下列程序段执行后的结果:
movsi,600h movdi,601h movax,ds moves,ax
movcx,256 std repmovsb〔解答〕
〔习题〕说明下列程序段的功能
cld
movax,0fefh movcx,5 movbx,3000h moves,bx movdi,20XXh repstosw〔解答〕
将es:
di(即3000:
20XXh或320XXh)开始的5个单元的内容置为0fefh。
〔习题〕指令指针IP是通用寄存器还是专用寄存器?
有指令能够直接它赋值吗?
哪类指令的执行会改变它的值?
指令指针IP不是通用寄存器,不可直接赋值,属于专用寄存器。
有且仅有循环、转移、子程序调用和返回、中断类等指令可以改变它的值。
〔习题〕控制转移类指令中有哪三种寻址方式?
控制转移类指令的寻址方式:
相对寻址、直接寻址方式和间接寻址方式。
〔习题〕什么是短转移shortjump、近转移nearjump和远转移farjump?
什么是段内转移和段间转移?
8086有哪些指令可以实现段间转移?
短转移:
指段内-128~127之间的转移,位移量用一个字节表示近转移:
指段内±
32K之间的转移,位移量用一个字表示远转移:
指段间1MB范围的转移
段内转移:
指在同一个代码段内的转移,可以是短转移或者近转移段间转移:
指转移到另外一个代码段,就是远转移
8086/8088CPU的JMP、CALL和INTn指令可以实现段间转移
〔习题〕8086的条件转移指令的转移范围有多大?
实际编程时,你如何处理超出范围的条件转移?
8086的条件转移的转移范围:
在当前指令地址的+127~-128之内。
如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围外的目标地址。
〔习题〕假设DS=20XXH,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?
JMPBX
JMPTABLE[BX]JMP[BX][SI]〔解答〕
转移的有效地址EA=BX=1256H
转移的有效地址EA=[DS:
20A1H+1256H]=[232F7]=3280H转移的有效地址EA=[DS:
1256H+528FH]=264E5H=2450H
〔习题〕判断下列程序段跳转的条件
xorax,1e1eh jeequal testal,10000001b jnzthere cmpcx,64h jbthere〔解答〕
AX=1e1ehAL的D0或D7至少有一位为1CX<64h
〔习题〕设置CX=0,则LOOP指令将循环多少次?
例如:
movcx,0delay:
loopdelay〔解答〕 216次。
〔习题〕假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:
若DX>
DI,转到above执行;
若AX>
SI,转到greater执行;
若CX=0,转到zero执行;
若AX-SI产生溢出,转到overflow执行;
若SI≤AX,转到less_eq执行;
若DI≤DX,转到below_eq执行。
DI,转到above执行 cmpdx,di
jaabove ;
=jnbeabove若AX>
SI,转到greater执行 cmpax,si
jggreater ;
=jnlegreater若CX=0,转到zero执行 cmpcx,0
jzzero ;
=jcxzz
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 新版 汇编语言 程序设计 课后 答案