新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc

上传人:wj 文档编号:887172 上传时间:2023-04-29 格式:DOC 页数:49 大小:159KB
下载 相关 举报
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第1页
第1页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第2页
第2页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第3页
第3页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第4页
第4页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第5页
第5页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第6页
第6页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第7页
第7页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第8页
第8页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第9页
第9页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第10页
第10页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第11页
第11页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第12页
第12页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第13页
第13页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第14页
第14页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第15页
第15页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第16页
第16页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第17页
第17页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第18页
第18页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第19页
第19页 / 共49页
新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc_第20页
第20页 / 共49页
亲,该文档总共49页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc

《新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc》由会员分享,可在线阅读,更多相关《新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc(49页珍藏版)》请在冰点文库上搜索。

新版汇编语言程序设计习题答案(钱晓捷主编)-20Word文档格式.doc

由于与处理器密切相关导致通用性差、可移植性差,汇编语言功能有限,

又涉及寄存器、主存单元等硬件细节,编写汇编语言比较繁琐,调试起来也比较困难,编译程序产生的目标

程序往往比较庞大、程序难以优化,运行速度慢。

〔习题1.5〕将下列十六进制数转换为二进制和十进制表示

(1)FFH 

(2)0H 

(3)5EH 

(4)EFH

(5)2EH 

(6)10H 

(7)1FH 

(8)ABH

11111111B 

255D 

(2)0H 

0B 

0D 

(3)5EH 

1011110B 

94D

(4)EFH 

11101111B 

239D

101110B 

46D

(6)10H 

10000B 

16D

(7)1FH 

11111B 

31D

(8)ABH 

10101011B 

171D

〔习题1.6〕

将下列十进制数转换为BCD码表示

(1)12 

(2)24 

(3)68 

(4)127

(5)128 

(6)255 

(7)1234 

(8)2458

00010010 

(2)24 

00100100 

(3)68 

01101000 

(4)127 

000100100111

000100101000 

(6)255 

001001010101

(7)1234 

0001001000110100

(8)2458 

0010010001011000

〔习题1.7〕

将下列BCD码转换为十进制数

(1)10010001 

(2)10001001 

(3)00110110 

(4)10010000

(5)00001000 

(6)10010111 

(7)10000001 

(8)00000010

(1)91 

(2)89 

(3)36 

(4)90

(5)08 

(6)97

(7)81 

(8)02

〔习题1.8〕将下列十进制数分别用8位二进制数的原码、反码和补码表示

(1)0 

(2)-127 

(3)127 

(4)-57

(5)126 

(6)-126 

(7)-128 

(8)68

+0 

00000000 

-0 

10000000 

11111111 

00000000

(2)-127 

10000001

(3)127 

01111111 

(4)-57 

10101111 

11010000 

11010001

01111110 

01111110

(6)-126 

11111110 

10000001 

10000010

(7)-128 

10000000

(8)68 

01000100 

01000100

〔习题1.9〕完成下列二进制数的运算

(1)1011+1001 

(2)1011-1001 

(3)1011×

1001 

(4)10111000÷

1001

(5)1011∧1001 

(6)1011∨1001(7)~1011 

(8)1011?

1001

(1)1011+1001=10100 

(2)1011-1001=0010 

(3)1011×

1001=1100011 

(4)10111000÷

1001=10100,余数1000

(5)1011∧1001=1001 

(6)1011∨1001=1011 

(7)~1011=0100 

(8)1011?

1001=0010(?

代表异或)

〔习题1.10〕数码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分别对应回车和换行控制字符。

〔习题1.11〕计算机中有一个“01100001”编码,如果把它认为是无符号数,它是十进制什么数?

如果认为

它是BCD码,则表示什么数?

又如果它是某个ASCII码,则代表哪个字符?

十进制无符号数:

01100001B=61H=97

BCD码:

61

ASCII码:

a

〔习题1.12〕简述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指令,

2000年推出的Pentium4新增了76条SSE2指令

〔习题1.13〕什么是DOS和ROM-BIOS?

DOS是DisketteOperatingsystem的缩写,意思是磁盘操作系统,DOS主要是面向磁盘的系统软件,说得简

单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层“外壳”,是1981~1995年的个人电脑上使用

的一种主要的操作系统。

BIOS(BasicInput/OutputSystem)即基本输入输出系统,通常是固化在只读

存储器(ROM)中,所以又称为ROM-BIOS。

它直接对计算机系统中的输入、输出设备进行设备级、硬件级的

控制,是连接软件程序和硬件设备之间的枢纽。

ROM-BIOS是计算机系统中用来提供最低级、最直接的硬件

控制的程序。

〔习题1.14〕简述PC机最低1MB主存空间的使用情况。

(1)基本RAM区(00000H—9FFFFH)该区共640KB,由DOS进行管理。

在这个区域中操作系统要占用掉一部分

低地址空间,其它则向用户程序开放。

(2)保留区RAM(A0000H--BFFFFFH)该区为系统安排的“显示缓冲存储区”,共126KB,是显卡上的芯片

提供支持,用于存放屏幕显示信息。

但这部分地址空间实际上并没有全部使用。

(3)扩展区ROM(C0000H--DFFFFH)该区128KB,由接口卡上的芯片提供支持,用于为系统不直接支持的外

设安排设备驱动程序。

用户固化的程序就可[安排在这一段,系统的会对它进行确认和连接。

(4)系统区ROM(E0000H--FFFFFH)该区共128KB,由系统占用,它主要提供ROM--BIOS程序,基本输入输

出程序BIOS,是操作系统的重要组成部分,主要用来驱动输入输出设备,也负责系统的上电检测,磁盘引导

等初始化操作,在ROM--BIOS中还有CMOS微机设置程序以及使用的字符图符信息等内容。

〔习题1.15〕罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用。

(1)数据寄存器:

AX称为累加器,使用频度最高,用于算术、逻辑运算以及与外设传送信息等;

BX称为基

址寄存器,常用做存放存储器地址;

CX称为计数器,作为循环和串操作等指令中的隐含计数器;

DX称为数据

寄存器,常用来存放双字长数据的高16位,或存放外设端口地址。

(2)指针及变址寄存器包括SI,DI,BP,SP,四个寄存器,常用于存储器寻址时提供地址。

SI是源变址寄存器

,DI是目的变址寄存器,一般与DS联用确定数据段和附加段中某一存储单元地址,在串指令中,SI与DS联用

、DI和ES联用,分别寻址数据段和附加段;

同时,在串指令中,SI和DI还都具有自动增量或减量的功能。

S

P,为堆栈指针寄存器,指示栈顶的偏移地址;

BP为基地址指针寄存器,表示堆栈段中的基地址。

SP与BP寄

存器均可与SS段寄存器联合使用以确定堆栈段中的存储单元地址。

〔习题1.16〕什么是标志,它有什么用途?

状态标志和控制标志有什么区别?

画出标志寄存器FLAGS,说明

各个标志的位置和含义。

标志用于反映指令执行结果或控制指令执行形式。

它是汇编语言程序设计中必须特别注意的一个方面,状态

用来记录运行的结果的状态信息,许多指令的执行都将相应地设置它,控制标志位可由程序根据需要用指令

设置,用来控制处理器执行指令的方式。

CF是进位标志;

ZF是零标志;

SF是符号标志;

PF奇偶标志;

OF溢出标志;

AF辅助进位标志;

DF方向标志;

IF中断允许标志;

TF陷阱标志。

〔习题1.17〕举例说明CF和OF标志的差异。

溢出标志OF和进位标志CF是两个意义不同的标志。

进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确;

溢出标志表示有符号数运算结果是否超

出范围,运算结果已经不正确。

例1:

3AH+7CH=B6H

无符号数运算:

58+124=182,范围内,无进位

有符号数运算:

58+124=182,范围外,有溢出

例2:

AAH+7CH=

(1)26H

170+124=294,范围外,有进位

-86+124=28,范围内,无溢出

〔习题1.18〕字和双字在存储器中如何存放,什么是“小端方式”?

对字和双字存储单元,什么是它们的对

齐地址?

为什么要对齐地址?

字或双字在存储器中占相邻的2个或4个存储单元;

存放时,低字节存入低地址,高字节存入高地址;

字或双

字单元的地址用它的低地址来表示。

80x86处理器采用的这种“低对低,高对高”的存储形式,被称为“小

端方式”;

将字单元安排在偶地址,双字节单元安排在模4地址,被称为“地址对齐方式”因为对于不对齐

地址的数据,处理器访问时,需要额外的访问时间,所以通常应该将数据的地址对齐,以取得较高的存取速

度。

〔习题1.19〕什么是8086中的逻辑地址和物理地址?

逻辑地址如何转换成物理地址?

请将如下逻辑地址用物

理地址表达:

(1)FFFFh:

(2)40h:

17h 

(3)2000h:

4500h 

(4)B821h:

4567h

在8086处理器中,对应每个物理存储单元都有一个唯一的20位编号,就是物理地址,从00000H~FFFFFH。

在8086内部和用户编程时,采用的段基地址:

段内偏移地址形式称为逻辑地址。

将逻辑地址中的段地址左移二进制4位(对应16进制是一位,即乘以16),加上偏移地址就得到20位物理地

如下逻辑地址用物理地址表达:

0=FFFF0H

(2)40h:

17h=00417H

(3)2000h:

4500h=24500H

(4)B821h:

4567h=BC777H 

(不要算错)

〔习题1.20〕8086有哪4种逻辑段,各种逻辑段分别是什么用途?

代码段(CodeSegment)用来存放程序的指令序列。

处理器利用CS:

IP取得下一条要执行的指令。

堆栈段(StackSegment)确定堆栈所在的主存区域。

处理器利用SS:

SP操作堆栈中的数据。

数据段(DataSegment)存放当前运行程序所用的数据。

处理器利用DS:

EA存取数据段中的数据。

附加段(ExtraSegment)是附加的数据段,也用于数据的保存。

处理器利用ES:

EA存取数据段中的数据

〔习题1.21〕数据的默认段是哪个,是否允许其他段存放数据?

如果允许,如何实现,有什么要求?

数据的默认段是安排在数据段,也经常安排在附加段,尤其是串操作的目的区必须是附加段,允许其它段存

放数据,数据的存放比较灵活的,实际上可以存放在任何一种逻辑段中,这时,只要明确指明是哪个逻辑段

就可以了。

〔习题1.22〕什么是操作码、操作数和寻址方式?

有哪三种给出操作数的方法?

操作码说明计算机要执行哪种操作,它是指令中不可缺少的组成部分,操作数是指令执行的参与者,也是各

种操作的对象,我们把寻找数的方式叫做操作数的寻址方式。

给出操作数的三种方法是直接给出,间接给出

,隐藏操作数方式给出。

〔习题1.23〕什么是有效地址EA?

8086的操作数如果在主存中,有哪些寻址方式可以存取它?

DS存放数据段的段地址,存储器中操作数的偏移地址则由各种主存方式得到,称之为有效地址EA。

8086的操

作数如果在主存中,可以存取它的寻址方式有直接寻址方式、寄存器间接寻址方式、寄存器相对寻址方式、

基址变址寻址方式、相对基址变址寻址方式。

〔习题1.24〕说明下列指令中源操作数的寻址方式?

如果BX=2000H,DI=40H,给出DX的值或有效地址EA

的值。

(1)movdx,[1234h]

(2)movdx,1234h

(3)movdx,bx

(4)movdx,[bx]

(5)movdx,[bx+1234h]

(6)movdx,[bx+di]

(7)movdx,[bx+di+1234h]

(1)直接寻址,EA=1234H

(2)立即数寻址,DX=1234H

(3)寄存器寻址,DX=2000H

(4)间接寻址,EA=2000H

(5)相对寻址,EA=3234H

(6)基址变址寻址,EA=2040H

(7)相对基址变址寻址,EA=3274H

第2章8086的指令系统

〔习题2.1〕已知DS=2000H、BX=0100H、SI=0002H,存储单元[20100H]~[20103H]依次存放123456

78H,[21200H]~[21203H]依次存放2A4CB765H,说明下列每条指令执行完后AX寄存器的内容。

(1)movax,1200h

(2)movax,bx

(3)movax,[1200h]

(4)movax,[bx]

(5)movax,[bx+1100h]

(6)movax,[bx+si]

(7)movax,[bx][si+1100h]

(1)AX=1200H

(2)AX=0100H

(3)AX=4C2AH 

;

偏移地址=bx=0100h

(4)AX=3412H 

(5)AX=4C2AH 

偏移地址=bx+1100h=1200h

(6)AX=7856H 

偏移地址=bx+si=0100h+0002h=0102h

(7)AX=65B7H 

偏移地址=bx+si+1100h=0100h+0002h+1100h=1202h

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

(1)movcx,dl

(2)movip,ax

(3)moves,1234h

(4)moves,ds

(5)moval,300

(6)mov[sp],ax

(7)movax,bx+di

(8)mov20h,ah

(1)两操作数类型不匹配

(2)IP指令指针禁止用户访问

(3)立即数不允许传给段寄存器

(4)段寄存器之间不允许传送

(5)两操作数类型不匹配

(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

p

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

当前位置:首页 > 人文社科 > 法律资料

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2