《新版汇编语言程序设计1-5章【课后答案】.pdf》由会员分享,可在线阅读,更多相关《新版汇编语言程序设计1-5章【课后答案】.pdf(74页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!新版汇编语言程序设计【课后习题答案】第 1 章 汇编语言基础知识 习题 1.1简述计算机系统的硬件组成及各部分作用。解答 CPU:包括运算器、控制器和寄存器组。运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据。存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。外部设备:实现人机交换和机间的通信。习题 1.2明确下列概念或符号:主存和辅存,RAM 和 ROM,存储器地址
2、和 I/O 端口,KB、MB、GB 和 TB 解答 主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU 需要通过 I/O 接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢。RAM 是随机存取存储器的英语简写,由于 CPU 可以从 RAM 读信息,也可以向 RAM 写入信息,所以 RAM 也被称为读写存储器,RAM 型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而 ROM 中的信息只能被读出,不能被修改,RO
3、M 型半导体通常只能被读出,但这类存储器断电后能保存信息。存储器由大量存储单元组成。为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O 接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成 I/O 地址,通常称做 I/O 端口。KB 是千字节、MB 是兆字节、GB 是吉字节和 TB 是太字节,它们都是表示存储器存储单元的单位。习题 1.3什么是汇编语言源程序、汇编程序、目标程序?解答 用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序。习题 1.4汇编语言与高级语言相比有什么优缺点?解答 汇编语
4、言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在“时间”和“空间”两方面最有效的程序。汇编语言与高级语言相比的缺点:由于与处理器密切相关导致通用性差、可移植性差,汇编语言功能有限,又涉及寄存器、主存单元等硬件细节,编写汇编语言比较繁琐,调试起来也比较困难,编译程序产生的目标程序往往比较庞大、程序难以优化,运行速度慢。欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 1.5将下列十六进制数转换为二进制和十进制表示 (
5、1)FFH (2)0H (3)5EH (4)EFH(5)2EH (6)10H (7)1FH (8)ABH 解答(1)FFH 11111111B 255D (2)0H 0B 0D (3)5EH 1011110B 94D (4)EFH 11101111B 239D (5)2EH 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 解答 (1)12 00
6、010010 (2)24 00100100 (3)68 01101000 (4)127 000100100111 (5)128 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)1000000
7、1 (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 解答 (1)0 +0 00000000 00000000 00000000 -0 10000000 11111111 00000000 (2)-127 11111111 10000000 10000001 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提
8、供优质的文档!(3)127 01111111 01111111 01111111 (4)-57 10101111 11010000 11010001 (5)126 01111110 01111110 01111110 (6)-126 11111110 10000001 10000010 (7)-128 10000000 (8)68 01000100 01000100 01000100 习题 1.9完成下列二进制数的运算 (1)10111001 (2)10111001 (3)10111001 (4)101110001001 (5)1011 1001 (6)1011 1001(7)1011 (8)
9、1011?1001 解答 (1)10111001=10100 (2)10111001=0010 (3)10111001=1100011 (4)101110001001=10100,余数 1000 (5)1011 1001=1001 (6)1011 1001=1011 (7)1011=0100 (8)1011?1001=0010(?代表异或)习题 1.10 数码09、大写字母AZ、小写字母 az对应的ASCII码分别是多少?ASCII码为 0dh、0ah 对应的是什么字符?解答 数码 09:30H39H 大写字母 AZ:41H5AH 小写字母 az:61H7AH 欢迎您阅读并下载本文档,本文档来
10、源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!ASCII 码为 0dh、0ah 分别对应回车和换行控制字符。习题 1.11计算机中有一个“01100001”编码,如果把它认为是无符号数,它是十进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?解答 十进制无符号数:01100001B61H97 BCD 码:61 ASCII 码:a 习题 1.12简述 Intel 80 x86 系列微处理器在指令集方面的发展。解答 1978 年 Intel,正式推出了 16 位 8086CPU,1979 年 Intel 推出了准 16 位微处理器 8088
11、,随后,Intel 推出了 80186/80188,80186/80188 指令系统比 8086 指令系统新增了若干条实用的指令,涉及堆栈操作、移位指令、过程指令和边界检测及乘法指令,1982 年 Intel 推出 80286 CPU,80286 指令系统包括全部 80186 指令及新增的保护指令 15 条,其中有些保护方式在实方式下也可以使用,1985 年,Intel80 x86 推出微处理器地进入第三代 80386 CPU,80386指令系统在兼容原来 16 位指令系统的基础上,全面升级为 32 位,还新增了有关位操作、条件设置指令以及控制、调试和测试寄存器的传送指令等,1989 年,In
12、tel 推出了80486CPU,80486 将浮点处理单元 FPU 集成进来,还采用了精简指令集计算机技术 RISC 和指令流水线方式,还新增了用于多处理器和内部 Cache 操作的 6 条指令,1993 年 Intel 制成了俗称 586 的微处理器,取名 Pentium。Pentium 仍为 32 位结构,地址总线为 32 位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium 新增了一条 8 字节比较交换指令和一条处理器识别指令,以及 4 条系统专用指令,1996 年推出了 MMX Pentium,新增了57条多媒休指令,1995年Intel推出Pentium Pro新增
13、了3条指令,1999年推出了Pentium新增了 70 条 SSE 指令,2000 年推出的 Pentium4 新增了 76 条 SSE2 指令 习题 1.13什么是 DOS 和 ROM-BIOS?解答 DOS 是 Diskette Operating system 的缩写,意思是磁盘操作系统,DOS 主要是面向磁盘的系统软件,说得简单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层“外壳”,是19811995 年的个人电脑上使用的一种主要的操作系统。BIOS(Basic InputOutput System)即基本输入输出系统,通常是固化在只读存储器(ROM)中,所以又称为 ROMBIO
14、S。它直接对计算机系统中的输入、输出设备进行设备级、硬件级的控制,是连接软件程序和硬件设备之间的枢纽。ROMBIOS 是计算机系统中用来提供最低级、最直接的硬件控制的程序。欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 1.14简述 PC 机最低 1MB 主存空间的使用情况。解答 (1)基本 RAM 区(00000H9FFFFH)该区共 640KB,由 DOS 进行管理。在这个区域中操作系统要占用掉一部分低地址空间,其它则向用户程序开放。(2)保留区 RAM(A0000H-BFFFFFH)该区为系统安排的“显示缓冲存储区”,共 126KB,是
15、显卡上的芯片提供支持,用于存放屏幕显示信息。但这部分地址空间实际上并没有全部使用。(3)扩展区 ROM(C0000H-DFFFFH)该区 128KB,由接口卡上的芯片提供支持,用于为系统不直接支持的外设安排设备驱动程序。用户固化的程序就可安排在这一段,系统的会对它进行确认和连接。(4)系统区 ROM(E0000H-FFFFFH)该区共 128KB,由系统占用,它主要提供 ROM-BIOS程序,基本输入输出程序 BIOS,是操作系统的重要组成部分,主要用来驱动输入输出设备,也负责系统的上电检测,磁盘引导等初始化操作,在 ROM-BIOS 中还有 CMOS 微机设置程序以及使用的字符图符信息等内容
16、。习题 1.15罗列 8086CPU 的 8 个 8 位和 16 位通用寄存器,并说明各自的作用。解答 (1)数据寄存器:AX 称为累加器,使用频度最高,用于算术、逻辑运算以及与外设传送信息等;BX 称为基址寄存器,常用做存放存储器地址;CX 称为计数器,作为循环和串操作等指令中的隐含计数器;DX 称为数据寄存器,常用来存放双字长数据的高 16 位,或存放外设端口地址。(2)指针及变址寄存器包括 SI,DI,BP,S P,四个寄存器,常用于存储器寻址时提供地址。SI是源变址寄存器,DI 是目的变址寄存器,一般与 DS 联用确定数据段和附加段中某一存储单元地址,在串指令中,SI 与 DS 联用、
17、DI 和 ES 联用,分别寻址数据段和附加段;同时,在串指令中,SI 和 DI 还都具有自动增量或减量的功能。S P,为堆栈指针寄存器,指示栈顶的偏移地址;BP 为基地址指针寄存器,表示堆栈段中的基地址。S P 与 BP 寄存器均可与SS 段寄存器联合使用以确定堆栈段中的存储单元地址。习题 1.16什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器 FLAGS,说明各个标志的位置和含义。解答 标志用于反映指令执行结果或控制指令执行形式。它是汇编语言程序设计中必须特别注意的一个方面,状态用来记录运行的结果的状态信息,许多指令的执行都将相应地设置它,控制标志位可由程序根据需要用
18、指令设置,用来控制处理器执行指令的方式。欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!在 8086 处理器中,对应每个物理存储单元都有一个唯一的 20 位编号,就是物理地址,从00000HFFFFFH。在 8086 内部和用户编程时,采用的段基地址:段内偏移地址形式称为逻辑地址。将逻辑地址中的段地址左移二进制 4 位(对应 16 进制是一位,即乘以 16),加上偏移地址就得到 20 位物理地址 如下逻辑地址用物理地址表达:(1)FFFFh:0FFFF0H
19、 (2)40h:17h00417H (3)2000h:4500h24500H (4)B821h:4567hBC777H (不要算错)习题 1.208086 有哪 4 种逻辑段,各种逻辑段分别是什么用途?解答 代码段(Code Segment)用来存放程序的指令序列。处理器利用 CS:IP 取得下一条要执行的指令。堆栈段(Stack Segment)确定堆栈所在的主存区域。处理器利用 SS:SP 操作堆栈中的数据。数据段(Data Segment)存放当前运行程序所用的数据。处理器利用 DS:EA 存取数据段中的数据。附加段(Extra Segment)是附加的数据段,也用于数据的保存。处理器利
20、用 ES:EA 存取数据段中的数据 习题 1.21数据的默认段是哪个,是否允许其他段存放数据?如果允许,如何实现,有什么要求?解答 数据的默认段是安排在数据段,也经常安排在附加段,尤其是串操作的目的区必须是附加段,允许其它段存放数据,数据的存放比较灵活的,实际上可以存放在任何一种逻辑段中,这时,只要明确指明是哪个逻辑段就可以了。欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 1.22什么是操作码、操作数和寻址方式?有哪三种给出操作数的方法?解答 操作码说明计算机要执行哪种操作,它是指令中不可缺少的组成部分,操作数是指令执行的参与者,也是各种操
21、作的对象,我们把寻找数的方式叫做操作数的寻址方式。给出操作数的三种方法是直接给出,间接给出,隐藏操作数方式给出。习题 1.23 什么是有效地址 EA?8086 的操作数如果在主存中,有哪些寻址方式可以存取它?解答 DS 存放数据段的段地址,存储器中操作数的偏移地址则由各种主存方式得到,称之为有效地址 EA。8086 的操作数如果在主存中,可以存取它的寻址方式有直接寻址方式、寄存器间接寻址方式、寄存器相对寻址方式、基址变址寻址方式、相对基址变址寻址方式。习题 1.24说明下列指令中源操作数的寻址方式?如果 BX2000H,DI40H,给出 DX的值或有效地址 EA 的值。(1)mov dx,12
22、34h (2)mov dx,1234h (3)mov dx,bx (4)mov dx,bx (5)mov dx,bx+1234h (6)mov dx,bx+di (7)mov dx,bx+di+1234h 解答 (1)直接寻址,EA1234H (2)立即数寻址,DX1234H (3)寄存器寻址,DX2000H (4)间接寻址,EA2000H (5)相对寻址,EA3234H 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!(6)基址变址寻址,EA2040H (7)相对基址变址寻址,EA3274H 第 2 章 8086 的指令系统 习题 2.1已知 D
23、S2000H、BX0100H、SI0002H,存储单元20100H20103H依次存放 12 34 56 78H,21200H21203H依次存放 2A 4C B7 65H,说明下列每条指令执行完后 AX 寄存器的内容。(1)mov ax,1200h(2)mov ax,bx(3)mov ax,1200h(4)mov ax,bx(5)mov ax,bx+1100h(6)mov ax,bx+si(7)mov ax,bxsi+1100h 解答(1)AX1200H(2)AX0100H(3)AX4C2AH ;偏移地址=bx=0100h(4)AX3412H ;偏移地址=bx=0100h(5)AX4C2AH
24、 ;偏移地址=bx+1100h=1200h(6)AX7856H ;偏移地址=bx+si=0100h+0002h=0102h(7)AX65B7H ;偏移地址=bx+si+1100h=0100h+0002h+1100h=1202h 习题 2.2指出下列指令的错误(1)mov cx,dl(2)mov ip,ax(3)mov es,1234h 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!(4)mov es,ds(5)mov al,300(6)mov sp,ax(7)mov ax,bx+di(8)mov 20h,ah 解答(1)两操作数类型不匹配(2)I
25、P 指令指针禁止用户访问(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)的连续区域中。请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。lea bx,table mov al,8 xlat 解答 lea bx,table ;获取 table 的首地址,BX200H mov al,8
26、 ;传送欲转换的数字,AL8 xlat ;转换为格雷码,AL12H P35 习题 2.4什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?解答 堆栈是一种按“先进后出”原则存取数据的存储区域,位于堆栈段中,使用 SS 段寄存器记录其段地址;它的工作原则是先进后出;堆栈的两种基本操作是压栈和出栈,对应的指令是 PUSH 和 POP。习题 2.5已知 SS=2200H、SP=00B0H,画图说明执行下面指令序列时,堆栈区和 SP 的内容如何变化?欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!mov ax,8057h push ax
27、 mov ax,0f79h push ax pop bx pop bx 解答 mov ax,8057h push ax mov ax,0f79h push ax pop bx ;bx=0f79h pop bx ;DS:0f79h=8057h 习题 2.6给出下列各条指令执行后 AL 值,以及 CF、ZF、SF、OF 和 PF 的状态:mov al,89h add al,al add al,9dh 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!cmp al,0bch sub al,al dec al inc al 解答 mov al,89h ;AL
28、=89h CF ZF SF OF PF add al,al ;AL=12h 1 0 0 1 1;1000 1001+1000 1001 10001 0010 add al,9dh ;AL=0afh 0 0 1 0 1;0001 0010+1001 1101 1010 1111 cmp al,0bch ;AL=0afh 1 0 1 0 1;1010 1111-1011 1100*0100 0011 sub al,al ;AL=00h 0 1 0 0 1 dec al ;AL=0ffh 0 0 1 0 1;0000 0000-0000 0001 *1111 1111 inc al ;AL=00h
29、0 1 0 0 1;1111 1111 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!+0000 0001*1111 1111 习题 2.7设 X、Y、Z 均为双字数据,分别存放在地址为 X、X+2;Y、Y+2;Z、Z+2 的存储单元中,它们的运算结果存入 W 单元。阅读如下程序段,给出运算公式。mov ax,X mov dx,X+2 add ax,Y adc dx,Y+2 add ax,24 adc dx,0 sub ax,Z sbb dx,Z+2 mov W,ax mov W+2,dx 解答 WX+Y+24-Z 习题 2.8请分别用一条汇编语
30、言指令完成如下功能:(1)把 BX 寄存器和 DX 寄存器的内容相加,结果存入 DX 寄存器。(2)用寄存器 BX 和 SI 的基址变址寻址方式把存储器的一个字节与 AL 寄存器的内容相加,并把结果送到 AL 中。(3)用 BX 和位移量 0B2H 的寄存器相对寻址方式把存储器中的一个字和 CX 寄存器的内容相加,并把结果送回存储器中。(4)用位移量为 0520H 的直接寻址方式把存储器中的一个字与数 3412H 相加,并把结果送回该存储单元中。(5)把数 0A0H 与 AL 寄存器的内容相加,并把结果送回 AL 中。解答 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将
31、竭诚为您提供优质的文档!(1)ADD DX,BX(2)ADD AL,BX+SI(3)ADD BX+0B2H,CX(4)ADD WORD PTR 0520H,3412H(5)ADD AL,0A0H 习题 2.9设 X、Y、Z、V 均为 16 位带符号数,分别装在 X、Y、Z、V 存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。mov ax,X ;ax=X imul Y ;DX.AX=X*Y mov cx,ax ;cx=X*Y 的低 16 位 mox bx,dx ;bx=X*Y 的高 16 位 mov ax,Z ;ax=Z cwd add cx,ax ;cx=Z 的低 16
32、位+X*Y 的低 16 位 adc bx,dx ;bx=Z 的高 16 位+X*Y 的高 16 位+低位进位 sub cx,540 ;cx=Z 的低 16 位+X*Y 的低 16 位-540 sbb bx,0 ;bx=Z 的高 16 位+X*Y 的高 16 位+低位进位-低位借位 mov ax,V ;ax=V cwd sub ax,cx ;ax=V 的低 16 位-(Z 的低 16 位+X*Y 的低 16 位-540)sbb dx,bx ;dx=V 的高 16 位-(Z 的高 16 位+X*Y 的高 16 位+低位进位-低位借位)-低位借位 idiv X;/X 解答 V-(X*Y+Z-540)
33、/X 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!AX 存商,DX 存余数 习题 2.10指出下列指令的错误:(1)xchg si,30h(2)pop cs(3)sub si,di(4)push ah(5)adc ax,ds(6)add si,80h(7)in al,3fch(8)out dx,ah 解答(1)xchg 的操作数不能是立即数(2)不应对 CS 直接赋值(3)两个操作数不能都是存储单元(4)堆栈的操作数不能是字节量(5)adc 的操作数不能是段寄存器(6)没有确定是字节还是字操作(7)in 不支持超过 FFH 的直接寻址(8)ou
34、t 只能以 AL/AX 为源操作数 习题 2.11给出下列各条指令执行后的结果,以及状态标志 CF、OF、SF、ZF、PF 的状态。mov ax,1470h and ax,ax or ax,ax xor ax,ax not ax test ax,0f0f0h 解答 mov ax,1470h ;AX1470H CF ZF SF OF PF 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!and ax,ax ;AX1470H 0 0 0 0 0 ;0001 0100 0111 0000 or ax,ax ;AX1470H 0 0 0 0 0 xor a
35、x,ax ;AX0000H 0 1 0 0 1 not ax ;AXFFFFH 0 1 0 0 1 test ax,0f0f0h ;AXFFFFH 0 0 1 0 1 注意:MOV 和 NOT 指令不影响标志位;其他逻辑指令使 CFOF0,根据结果影响其他标志位。习题 2.12假设例题 2.32 的程序段中,AX=08H,BX=10H,请说明每条指令执行后的结果和各个标志位的状态。解答 指令 ;执行结果 CF OF SF ZF PF mov si,ax ;SI=AX=0008H -shl si,1 ;SI=2*AX=0010H 0 0 0 0 0 add si,ax ;SI=3*AX=0018
36、H 0 0 0 0 1 mov dx,bx ;DX=BX=0010H 0 0 0 0 1 mov cl,03h ;CL=03H 0 0 0 0 1 shl dx,cl ;DX=8*BX=0080H 0 u 0 0 0 sub dx,bx ;DX=7*BX=0070H 0 0 0 0 0 add dx,si ;DX=7*BX+3*AX=0088H 0 0 0 0 1 注意:逻辑左移 N 次相当于无符号整数乘以 2 的 N 次方,逻辑右移 N 次相当于无符号整数除以 2的 N 次方。移位指令根据移位的数据设置 CF,根据移位后的结果影响 SF,ZF,PF。在进行一位移位时,根据最高符号位是否改变设
37、置 OF,如改变则 OF1。另外,程序注释用“u”表示标志无定义(不确定),“-”表示无影响。习题 2.13编写程序段完成如下要求:(1)用位操作指令实现 AL(无符号数)乘以 10(2)用逻辑运算指令实现数字 0 9 的 ASCII 码与非压缩 BCD 码的互相转换(3)把 DX.AX 中的双字右移 4 位 解答(1);不考虑进位 mov bl,al 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!mov cl,3 shl al,cl ;*8 add al,bl ;shl bl,1 add al,bl ;考虑进位 xor ah,ah mov bx
38、,ax mov cl,3 shl ax,cl add ax,bx ;shl bx,1 add ax,bx(2)数字 09 的 ASCII 码是:30h39h 非压缩 BCD 码的 09 是:00h09h 方法一:and al,0fh ;实现 ASCII 到非压缩 BCD 码的转换 or al,30h ;实现非压缩 BCD 码到 ASCII 的转换 方法二:xor al,30h ;求反 D5D4 位,其他不变 ;即高 4 位为 3,则变为 0;高 4 位为 0,则变为 3(3)mov cl,4 again:shr dx,1 ;实现逻辑右移 ;采用“sar dx,1”,则实现算术右移 rcr ax
39、,1 dec cl jnz again 习题 2.14已知 AL=F7H(表示有符号数-9),分别编写用 SAR 和 IDIV 指令实现的除以 2 的程序段,并说明各自执行后,所得的商是什么?解答(1)用 sar 编写 mov al,0f7h ;-9 送 AL 1111 1001 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!sar al,1 ;结果:AL=1111 1100B=0FBH 即-5(2)用 idiv 编写 mov al,0f7h ;-9 送 al cbw ;字节符号扩展位字 mov bl,2 ;注意除数不可为立即数 idiv bl
40、;结果:商为 al=fch (-4);余数:ah=ffh(-1)结论:符号数的除法用 idiv 准确。习题 2.15已知数据段 500h 600h 处存放了一个字符串,说明下列程序段执行后的结果:mov si,600h mov di,601h mov ax,ds mov es,ax mov cx,256 std rep movsb 解答 习题 2.16说明下列程序段的功能 cld mov ax,0fefh mov cx,5 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!mov bx,3000h mov es,bx mov di,2000h rep
41、 stosw 解答 将 es:di(即 3000:2000h 或 32000h)开始的 5 个单元的内容置为 0fefh。习题 2.17指令指针 IP 是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指令的执行会改变它的值?解答 指令指针 IP 不是通用寄存器,不可直接赋值,属于专用寄存器。有且仅有循环、转移、子程序调用和返回、中断类等指令可以改变它的值。习题 2.18控制转移类指令中有哪三种寻址方式?解答 控制转移类指令的寻址方式:相对寻址、直接寻址方式和间接寻址方式(又可以分成寄存器和存储器间接寻址)。习题 2.19什么是短转移 short jump、近转移 near jump 和
42、远转移 far jump?什么是段内转移和段间转移?8086 有哪些指令可以实现段间转移?解答 短转移:指段内128127 之间的转移,位移量用一个字节表示 近转移:指段内32K 之间的转移,位移量用一个字表示 远转移:指段间 1MB 范围的转移 段内转移:指在同一个代码段内的转移,可以是短转移或者近转移 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!段间转移:指转移到另外一个代码段,就是远转移 8086/8088CPU 的 JMP、CALL 和 INT n 指令可以实现段间转移 习题 2.208086 的条件转移指令的转移范围有多大?实际编程时
43、,你如何处理超出范围的条件转移?解答 8086 的条件转移的转移范围:在当前指令地址的+127-128 之内。如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围外的目标地址。习题 2.21假设 DS=2000H,BX=1256H,SI=528FH,位移量 TABLE=20A1H,232F7H=3280H,264E5H=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?(1)JMP BX(2)JMP TABLEBX(3)JMP BXSI 解答(1)转移的有效地址 EA=BX=1256H(2)转移的有效地址 EA=DS:20A1H+1256H=232
44、F7=3280H(3)转移的有效地址 EA=DS:1256H+528FH=264E5H=2450H 习题 2.22判断下列程序段跳转的条件 (1)xor ax,1e1eh je equal (2)test al,10000001b jnz there (3)cmp cx,64h jb there 解答(1)AX1e1eh(异或后为 0)(2)AL 的 D0 或 D7 至少有一位为 1(3)CX(无符号数)64h 习题 2.23设置 CX=0,则 LOOP 指令将循环多少次?例如:mov cx,0 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!de
45、lay:loop delay 解答 216 次。习题 2.24假设 AX 和 SI 存放的是有符号数,DX 和 DI 存放的是无符号数,请用比较指令和条件转移指令实现以下判断:(1)若 DX DI,转到 above 执行;(2)若 AX SI,转到 greater 执行;(3)若 CX=0,转到 zero 执行;(4)若 AXSI 产生溢出,转到 overflow 执行;(5)若 SIAX,转到 less_eq 执行;(6)若 DIDX,转到 below_eq执行。解答(1)若 DX DI,转到 above 执行 cmp dx,di ja above ;jnbe above(2)若 AX SI
46、,转到 greater 执行 cmp ax,si jg greater ;jnle greater(3)若 CX=0,转到 zero 执行 cmp cx,0 jz zero ;jcxz zero (4)若 AXSI 产生溢出,转到 overflow 执行;cmp ax,si jo overflow(5)若 SIAX,转到 less_eq 执行;cmp si,ax ;cmp ax,si jle less_eq ;jge less_eq(6)若 DIDX,转到 below_eq 执行。cmp di,dx ;cmp dx,di jbe below_eq ;jae below_eq 欢迎您阅读并下载本
47、文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!习题 2.25有一个首地址为 array 的 20 个字的数组,说明下列程序段的功能。mov cx,20 mov ax,0 mov si,ax sum_loop:add ax,arraysi add si,2 loop sum_loop mov total,ax 解答 将首地址为 array 得 20 个字的数组求和,并将结果存入 total 单元中。习题 2.26按照下列要求,编写相应的程序段:(1)起始地址为 string 的主存单元中存放有一个字符串(长度大于 6),把该字符串中的第 1 个和第 6 个字符(字节
48、量)传送给 DX 寄存器。(2)从主存 buffer 开始的 4 个字节中保存了 4 个非压缩 BCD 码,现按低(高)地址对低(高)位的原则,将它们合并到 DX 中。(3)编写一个程序段,在 DX 高 4 位全为 0 时,使 AX=0;否则使 AX=-1。(4)有两个 64 位数值,按“小端方式”存放在两个缓冲区 buffer1 和 buffer2 中,编写程序段完成buffer1buffer2 功能。(5)假设从 B800h:0 开始存放有 100 个 16 位无符号数,编程求它们的和,并把 32 位的和保存在 DX.AX 中。(6)已知字符串 string 包含有 32KB 内容,将其中
49、的$符号替换成空格。(7)有一个 100 个字节元素的数组,其首地址为 array,将每个元素减 1(不考虑溢出)存于原处。(8)统计以$结尾的字符串 srting 的字符个数。解答(1)解答:mov si,0 mov dl,stringsi ;第 1 个字符送 dl 寄存器:mov dl,stirng0 mov si,5 mov dh,stringsi ;第 6 个字符送 dh 寄存器:mov dl,stirng5(2)解答:xor si,si ;si 清零 欢迎您阅读并下载本文档,本文档来源于互联网,如有侵权请联系删除!我们将竭诚为您提供优质的文档!mov al,buffersi ;第一字
50、节 inc si mov ah,buffersi ;第二字节 mov cl,4 shl ah,cl ;BCD 码移到高半字节 or al,ah ;组合成压缩 BCD 码 mov dl,al ;存入 dl 寄.inc si mov al,buffersi ;第三字节 inc si mov ah,buffersi ;第四字节 mov cl,4 shl ah,cl ;BCD 码移到高半字节 or al,ah ;组合成压缩 BCD 码 mov dh,al ;存入 dh 寄.(3)解答:test dx,0f000h ;test dh,0f0h jz next ;jnz next mov ax,-1 ;m