1、微机原理习题第一章 绪论习题与答案1. 把下列二进制数转换成十进制数、十六进制数及 BCD 码形式。(1 ) 10110010B =(2 ) 01011101.101B =解:(1 ) 10110010B = 178D = B2H = (0001 0111 1000)BCD(2 ) 01011101.101B = 93.625D = 5D.AH= (1001 0011.0110 0010 0101)BCD2. 把下列十进制数转换成二进制数。(1 ) 100D =(2 ) 1000D =(3 ) 67.21D =解:(1 ) 100D = 01100100B(2 ) 1000D = 111110
2、1000B(3 ) 67.21D = 1000011.0011B3. 把下列十六进制数转换成十进制数、二进制数。(1) 2B5H =(2) 4CD.A5H =解: ( 1) 2B5H = 693D = 0010 1011 0101B( 2) 4CD.A5H = 1229.6445D = 0100 1100 1101.1010 0101 B4. 计算下列各式。(1 ) A7H+B8H =(2 ) E4H-A6H =解:(1 ) A7H+B8H = 15FH(2 ) E4H-A6H = 3EH5. 写出下列十进制数的原码、反码和补码。(1 ) +89(2 ) -37解:(1 ) +89 原码、反码
3、和补码为: 01011001B(2 ) -37 原码 = 10100101 B -37 反码 = 11011010 B-37 补码 = 11011011 B6求下列用二进制补码表示的十进制数(1) (01001101 )补 = (2) (10110101 )补 =解:(1) (01001101 )补 = 77D(2) (10110101 )补 = -75D 7请用 8 位二进制数写出下列字符带奇校验的 ASCII 码。(1)C: 1000011 (2)O: 1001111(3)M: 1001101 (4)P: 1010000解:(1)C:0 1000011 (2)O: 0 1001111(3)
4、M:1 1001101 (4)P : 1 10100008请用 8 位二进制数写出下列字符带偶校验的 ASCII 码。(1)+:0101011 (2)=: 0111101(3)#:0100011 (4): 0111110解:(1)+:0 0101011 ( 2)=: 1 0111101(3)#:1 0100011 ( 4): 1 01111109叙述 CPU 中 PC 的作用。解:PC 是 CPU 中的程序计数器,其作用是提供要执行指令的地址。第二章 微处理器体系与结构习题与答案1. 80868088 CPU 由哪两大部分组成?请分别叙述它们的功能。解:8086/8088 CPU 均由两个独立
5、的逻辑单元组成,一个称为总线接口单元 BIU(Bus Interface Unit) ,另一个称为执行单元 EU(Execution Unit) 。总线接口单元 BIU 取指令时,从存储器指定地址取出指令送入指令队列排队;执行指令时,根据 EU 命令对指定存储器单元或 I/O 端口存取数据。执行单元 EU 任务是执行指令,进行全部算术逻辑运算、完全偏移地址的计算,向总线接口单元 BIU 提供指令执行结果的数据和偏移地址,并对通用寄存器和标志寄存器进行管理。2. 8086 8088 与传统的计算机相比在执行指令方面有什么不同?这样的设计思想有什么优点?解:总线接口部分和执行部分是分开的,每当 E
6、U 执行一条指令时,造成指令队列空出 2个或空出一个指令字节时 ,BIU 马上从内存中取出下面一条或几条指令,以添满他的指令队列。这样,一般情况下,CPU 在执行完一条指令后,便可马上执行下一条指令,不像以往 8 位 CPU 那样,执行完一条指令后,需等待下一条指令。即 EU 从指令队列中取指令、执行指令和 BIU 补充指令队列的工作是同时进行的。这样大大提高了 CPU 利用率,降低了系统都对存储器速度的要求。 3. 状态标志和控制标志有何不同?80868088 的状态标志和控制标志分别有哪些?解:8086/8088 CPU 设立了一个两字节的标志寄存器,共九个标志。其中标志位O、S、Z、A、
7、 P、C 是反映前一次涉及 ALU 操作结果的状态标志,D、I、T 是控制 CPU 操作特征的控制标志。4. 80868088 CPU 寻址存储器时,什么是物理地址?逻辑地址?它们之间有何关系?解:8086/8088 系统中每个存储单元都有一个物理地址,物理地址就是存储单元的实际地址编码。在 CPU 与存贮器之间进行任何信息交换时,需利用物理地址来查找所需要的访问的存储单元。逻辑地址由段地址和偏移地址两部分组成。逻辑地址的表示格式为:段地址:偏移地址。知道了逻辑地址,可以求出它对应的物理地址:物理地址= 段地址10H+偏移地址。5. 段寄存器 CS1200H,指令指针寄存器 IPFF00H,此
8、时,指令的物理地址为多少?指向这一物理地址的 CS 值和 IP 值是唯一的吗?解:根据:物理地址= 段地址10H+ 偏移地址,指令的物理地址为 21F00H。指向这一物理地址的 CS 值和 IP 值不唯一。6. 8086 CPU 中 信号和 A0 信号是通过怎样的组合解决存储器和外设端口的读写的?这种组合决定了 8086 系统中存储器偶地址体及奇地址体之间应该用什么信号区分?怎样区分?解:若存取一个字节的数据,总是用一个总线周期来完成该操作;若存取一个字,则依该字是规则字还是不规则字需用一个或两个总线周期来完成。对规则字,只用一个总线周期来完成 16 位数据的传送,而对于非规则字则用相邻两个总
9、线周期来完成该字的存储操作,先取其奇地址字节(即数据的低位字节) ,然后存取偶地址字节。在组成存储系统时,总是偶地址单元的数据通过 AD0AD7 传送,而奇地址单元的数据通过 AD8AD15 传送,即通过总线高字节传送。 信号和 A0 信号控制存储器读写见下表:操作 A0 使用的数据总线存取规则字 0 0 AD15AD0传送偶地址的一个字节1 0 AD7AD0传送奇地址的一个字节0 1 AD15AD80 1 AD15AD8(第一个总线周期)存取非规则字 1 0 AD7AD0(第二个总线周期)1 1 为非法码7什么叫总线?为什么各种微型计算机系统中普遍采用总线结构?答:总线是模块与模块之间传送信
10、息的一组公用信号线。总线标准的建立使得各种符合标准的模块可以很方便地挂在总线上,使系统扩展和升级变得高效、简单、易行。因此微型计算机系统中普遍采用总线结构。8微型计算机系统总线从功能上分为哪三类?它们各自的功能是什么?答:微型计算机系统总线从功能上分为地址总线、数据总线和控制总线三类。地址总线用于指出数据的来源或去向,单向;数据总线提供了模块间数据传输的路径,双向;控制总线用来传送各种控制信号或状态信息以便更好协调各功能部件的工作。9 8086/8088 CPU 分为哪两个部分?如何协调工作?答:EU 是执行部件,主要的功能是执行指令和形成有效地址。BIU 是总线接口部件,与片外存储器及 I/
11、O 接口电路传输数据,主要功能是形成实际地址、预取指令和存取操作数。EU 经过 BIU 进行片外操作数的访问, BIU 为 EU 提供将要执行的指令。 EU 与 BIU 可分别独立工作,当 EU 不需 BIU 提供服务时,BIU 可进行填充指令队列的操作。10 8086/8088 CPU的地址总线有多少位?其寻址范围是多少?答:8086/8088 CPU的地址总线共20 位,最大可寻址1MB空间。11 8086/8088 CPU使用的存储器为什么要分段?怎么分段?答:8086/8088 为16 位CPU ,其内部的ALU、相关的地址寄存器(如SP 、IP 以及BX、 BP、SI 、DI )等都
12、是16位的,因而对存储器地址的处理也只能是16位操作,即8086/8088的直接寻址能力在64KB范围内。而实际上8086/8088有20 条地址线,它的最大寻址空间为1MB 。这就产生了一个矛盾,即如何用16 位的地址寄存器去表示一个20位的存储器物理地址?实际使用的解决办法是:将1MB大小的存储空间分为若干“ 段”,每段不超过64KB。这样,一个20位的物理地址就可以用“16位段基址:16位偏移量” 的形式(称为逻辑地址)来表示了,其中段地址存放在8086/8088的段寄存器中。12 8086/8088 CPU 中有几个通用寄存器?有几个变址寄存器?有几个指针寄存器?通常哪几个寄存器亦可作
13、为地址寄存器使用?答:8086/8088 CPU 中共有:8个 16位的通用寄存器AX 、BX、CX 、DX 、BP、SP 、SI、DI;2个变址寄存器SI、DI;2个指针寄存器BP、SP;其中BX、BP 、SI、DI 亦可作地址寄存器。13 Intel 8086与8088有何区别?答:8086 与8088的区别主要表现在以下几个方面:第一、8086 的指令队列可以容纳6 个字节,每个总线周期在存储器中取出2个字节指令代码填入队列。而8088只能容纳4 个字节,且每个总线周期只能取出1个字节指令代码。第二、8086 外部数据总线宽度为16位,8088外部数据总线宽度只有 8位。注意:8086和
14、8088外部数据总线的宽度不同将导致扩展主存储器及输入 /输出接口时系统地址线和数据线连接方式的不同。第三、其他不同的引脚定义:(1)AD 15AD0,在8086 中为地址 /数据复用,而在8088中AD15AD8 改为A 15A8只作地址线用;(2 )34 、28号引脚定义不同。14 8086/8088CPU工作在最小模式时:当 CPU访问存储器时,要利用哪些信号?当CPU访问外设接口时,要利用哪些信号?答:8086/8088 CPU工作在最小模式时,若访问存储器,需用到以下信号:、ALE、 、DEN 、READY、 、 、 、AD0AD15 、A19/S6 A16/S3 。若IOM/RDT
15、/ BHEWRD访问外设,需用到以下信号:、ALE、 、DEN 、READY、 、 、AD0AD15 。/15 试指出下列运算后的各个状态标志,并说明进位标志和溢出标志的区别:(1 ) 1278H3469H答:CF=0 AF=1 ZF=0 SF=0 OF=0 PF=1(2 ) 54E3H27A0H答:CF=0 AF=0 ZF=0 SF=0 OF=0 PF=0(3 ) 3881H3597H答:CF=0 AF=0 ZF=0 SF=0 OF=0 PF=1(4 ) 01E3H01E3H答:CF=0 AF=0 ZF=1 SF=0 OF=0 PF=1其中,进位标志CF 用于判别无符号数运算是否超出数的表示
16、范围,而溢出标志OF 用于判别带符号数运算是否超出数的表示范围。奇偶标志PF 只能判断结果低8 位中“1”的个数为奇数还是偶数。16 什么是逻辑地址?什么是物理地址?它们之间有什么联系?各用在何处?答:逻辑地址由两个16 位的部分即段基址和偏移量组成,一般在程序中出现的地址都表示为逻辑地址形式;物理地址是一个20 位的地址,它是唯一能代表存储空间每个字节单元的地址,一般只出现在地址总线上。由于8086/8088CPU 中的寄存器只有16 位长,所以程序不能直接存放 20 位的物理地址,而必须借助逻辑地址,即用两个16 位的寄存器来表示物理地址。他们之间的关系是:物理地址段基址*16偏移量;另外
17、,一个物理地址可对应多个逻辑地址。17 设现行数据段位于存储器0B0000H0BFFFFH 单元,DS 段寄存器内容为多少?答: DS 段寄存器内容为0B000H。18在 8086 中,逻辑地址、偏移地址、物理地址分别指的是什么? 答:逻辑地址是在程序中对存储器地址的一种表示方法,由段基址和段内偏移地址两部分组成,都是 16 位的二进制代码,如 1234H:0088H。偏移地址是指段内某个存储单元相对该段首地址的差值。物理地址是 8086 芯片引线送出的 20 位地址码,物理地址=段基址*16+偏移地址,用来指出一个特定的存储单元。19 给定一个存放数据的内存单元的偏移地址是 20C0H, (
18、DS)=0C0E0H,求出该内存单元的物理地址。答:物理地址:0C2EC0H。20 8086/8088 为什么采用地址/数据引线复用技术?答:考虑到芯片成本和体积,8086/8088 采用 40 条引线的封装结构。40 条引线引出8086/8088 的所有信号是不够用的,采用地址/数据线复用引线方法可以解决这一矛盾,从逻辑角度,地址与数据信号不会同时出现,二者可以分时复用同一组引线。21 怎样确定 8086 的最大或最小工作模式? 答:引线 的逻辑状态决定 8086 的工作模式, 引线接高电平,8086 被MXN MXN设定为最小模式, 引线接低电平,8086 被设定为最大模式。22 8086
19、 基本总线周期是如何组成的?答:基本总线周期由 4 个时钟 (CLK)周期组成,按时间顺序定义为 T1、T2、T3、T4 。23在基于 8086 的微计算机系统中,存储器是如何组织的?存储器是如何与处理器总线连接的? 信号起什么作用?BHE答:8086 为 16 位微处理器,可访问 1M 字节的存储器空间; 1M 字节的存储器分为两个 512K 字节的存储体,分别命名为偶存储体和奇存储体;偶体的数据线连接 D7D0, “体选”信号接地址线 A0;奇体的数据线连接 D15D8, “体选”信号接 信号;A0 信号有效时允BHE许访问偶体中的低字节存储单元, 信号有效时允许访问奇体中的高字节存储单元
20、,实BHE现 8086 的低字节访问、高字节访问及字访问。24 有一个由 20 个字组成的数据区,其起始地址为 610AH:1CE7H。试写出该数据区首末单元的实际地址 PA。首单元地址:610A0H+1CE7H=62D87H末单元地址:62D87H27H=62DAEH25有两个 16 位的字 31DAH、5E7FH,它们在 8086 系统存储器中的地址为 00130H和 00135H,试画出它们的存储器示意图。地址 内容00130H 0DAH00131H 31H00132H00133H00134H00135H 7F00136H 5E26试说明 8086CPU 的控制引脚 ALE 的作用。答:
21、8086 的低位地址线与数据线复用,为保证地址线维持足够的时间,需使用 ALE 信号将低位地址线通过锁存器保存,以形成系统地址总线。第三章 80x86 指令系统习题与答案1、指出下列指令中操作数的寻址方式(8086 系统) 。(1 ) MOV AX,100 (2) MOV AX,100(3 ) MOV DL,BP+SI (4 ) MOV BX,CX(5 ) MOV DX,SI (6) MOV 1234HBX,DS(7 ) MOV DI+5678H,AL (8) MOV 12BPDI,BH(9 ) POP CX ( 10)MOV AX,BX+SI+10解: 目的操作数 源操作数(1 ) MOV
22、AX,100 寄存器寻址 立即数寻址(2 ) MOV AX,100 寄存器寻址 直接寻址(3 ) MOV DL,BP+SI 寄存器寻址 基址变址寻址(4 ) MOV BX,CX 寄存器间接寻址 寄存器寻址(5 ) MOV DX,SI 寄存器寻址 寄存器间接寻址(6 ) MOV 1234HBX,DS 寄存器相对寻址 寄存器寻址(7 ) MOV DI+5678H,AL 寄存器相对寻址 寄存器寻址(8 ) MOV 12BPDI,BH 相对基址变址寻址 寄存器寻址(9 ) POP CX 隐含为堆栈 寄存器寻址(10 )MOV AX,BX+SI+10 寄存器寻址 相对基址变址寻址2、指出下列指令中操作数
23、的寻址方式(80386 系统) 。(1 ) MOV EBX+12H,AX (2) MOV EBP+EDI*2,EBX(3 ) MOV EBX*4,BX (4 ) MOV EDX,EAX+ESI*8-12H解:目的操作数 源操作数(1)寄存器相对寻址 寄存器寻址 (2 )基址比例变址寻址 寄存器寻址(3)比例变址寻址 寄存器寻址(4 )寄存器寻址 相对基址比例变址寻址3、指出以下指令中,哪些指令是非法的,并说明为什么(8086 系统) 。(1 ) PUSH 1234H (2) MOV CS,AX(3 ) IN AX, 300 (4 ) MOV AX,DX+12(5 ) MOV BX,BX (6
24、) MOV DS,1000H(7 ) XCHG AL,AL (8) MOV AL,100H(9 ) MOV DX,AL (10)LEA BL,BX+5(11 )LEA DX,BX (12)MOV 1000H,12H(13 )ADD AX,DS (14 )SUB 0100H,BYTE PTR 0001(15 )SHL BL,2 (16)SHR CL,CL(17 )MUL AL,BL (18)INT 400解:(1)非法,8086 系统不允许 PUSH 指令的操作数为立即数;(2 )非法,MOV 指令中 CS 不能作为目的操作数;(3 )非法,端口号大于 0FFH;(4 )非法,DX 不能出现在中
25、括号 内;(5 )合法;(6 )非法,不能把立即数赋给段寄存器;(7 )合法;(8 )非法,源操作数大于 0FFH,不能赋给 8 位寄存器 AL;(9 )非法,源操作数是 8 位寄存器,目的操作数却是 16 位寄存器,不匹配;(10 )非法, LEA 指令得到的是 16 位偏移量,但目的操作数是 8 位寄存器;(11 )非法, LEA 指令的源操作数只能是存储器操作数;(12 )非法,指令存在歧义,无法确定传送的是字节还是字;(13 )非法,段寄存器不能参与算术运算;(14 )非法,源和目的寄存器不能同为存储器操作数;(15 )非法,在 8086 系统中,移位次数大于 1 时需要将移位次数存放
26、到 CL 中;(16 )合法;(17 )非法,在 8086 系统中 MUL 指令没有双操作数的用法;(18 )非法,中断类型号大于 0FFH。4、指出以下指令中,哪些指令是非法的,并说明为什么(80386 系统) 。(1 ) MOV AX,12EBXSI*16 (2 ) RCR EAX,10(3 ) PUSH 5678H (4) POP 1000H(5 ) MOV EAX+EAX,EAX (6) MOV AL,ESP+ESP*2(7 ) MOV BL,AX+12 (8 ) IMUL AL,BL ,12解:(1)非法,比例因子只能是 1、2、4 、8,不能是 16;(2 )合法;(3 )合法;(
27、4 )非法,POP 指令的目的操作数不能是立即数;(5 )合法;(6 )非法,ESP 只能作为基址寄存器,不能作为变址寄存器;(7 )非法,在 386 系统中 AX 不能作为基址寄存器,也不能作为变址寄存器;(8 )合法。5、假设(AX)=1234H,(BX)=5678H,(SP)=1000H,指出执行下面的程序段后,各相关寄存器及堆栈段中的内容。PUSH AX ;(AX)=? ,(BX)=?,(SP)=?,栈顶字节SP=?, 栈顶第二字节SP+1=?PUSH BX ;(AX)=?,(BX)=?,(SP)=?,栈顶字节SP=?, 栈顶第二字节SP+1=?POP AX ;(AX)=?,(BX)=
28、?,(SP)=?,栈顶字节SP=?, 栈顶第二字节SP+1=?解:(AX)=1234H ,(BX)=5678H ,(SP)=0FFEH,栈顶字节SP=34H,栈顶第二字节SP+1=12H(AX)=1234H,(BX)=5678H,(SP)=0FFCH ,栈顶字节SP=78H,栈顶第二字节SP+1=56H(AX)=5678H,(BX)=5678H,(SP)=0FFEH,栈顶字节SP=34H,栈顶第二字节SP+1=12H6、假设 A、B 、C、D、X、Y 为字节变量,AA、BB、YY 为字变量,试利用算术运算指令编写程序段,完成以下各算术运算题。(1 )计算 YYA+B*C,其中 A、B、C 都是
29、无符号数;(2 )计算(AA+BB)/(C-D) ,商赋给 X,余数赋给 Y,其中 AA、BB 、C、D 都是带符号数;(3 )计算 YY(A-B)*C,其中 A、B 、C 都是未组合 BCD 码。解:(1 ) MOV AL,BMUL CADD AL,AADC AH,0MOV YY, AX(2 ) MOV AX,AAADD AX,BBMOV BL,CSUB BL,DIDIV BLMOV X, ALMOV Y,AH(3 ) MOV AL,ASUB AL,BAASMUL CAAMMOV YY, AX7、利用移位指令编写程序段,实现以下运算。(1 )计算 AXAX*10,其中 AX 为无符号数;(2
30、 ) 32 位带符号数存放在寄存器 DX 和 AX 中,其中 DX 存放高 16 位,AX 存放低 16 位计算(DX,AX)(DX,AX)*2。(3 ) 32 位带符号数存放在寄存器 DX 和 AX 中,其中 DX 存放高 16 位,AX 存放低 16 位计算(DX,AX)(DX,AX)/2。解:(1 ) SHL AX,1MOV BX,AXSHL AX,1SHL AX,1ADD AX,BX(2 ) SAL AX,1RCL DX,1(3 ) SAR DX,1RCR AX,1 8、指出以下指令执行后,标志寄存器 OF、SF、ZF、AF 、PF、CF 的状态。(1 ) (AL)=0FFH,(BL)
31、=20H,执行指令:ADD AL,BL(2 ) (AL)=01H, (BL)=02H,执行指令:CMP AL,BL(3 ) (AL)=0FFH,执行指令:INC AL(4 ) (AL)=0,执行指令:DEC AL(5 ) (AL)=0F0H,(BL)=04H ,执行指令:IMUL BL(6 ) (AX)=1F0H,(BL)=08H ,执行指令:DIV BL(7 ) (AL)=12H, (BL)=34H,执行指令:TEST AL,BL(8 ) (AL)=98H,执行指令:SAL AL,1解:OF SF ZF AF PF CF(1 ) 0 0 0 0 0 1(2 ) 0 1 0 1 1 1(3 )
32、 0 0 1 1 1 (4 ) 0 1 0 1 1 (5 ) 0 0(6 ) (7 ) 0 0 0 0 0(8 ) 1 0 0 1 1注:0 表示结果为 0,1 表示结果为 1,表示结果不变,表示结果不确定。9、在 8086 系统下,编写实现如下功能的程序段:(1 )从地址为 80H 的端口中读入一个字节;(2 )如果该字节最高位为“1”,则将字节 0FFH 送到地址为 81H 的端口中,并退出程序;(3 )如果该字节最高位为“0”,则转向第(1)步,继续循环扫描。解: 参考程序段:AGAIN: IN AL, 80HTEST AL, 80HJZ AGAINMOV AL, 0FFHOUT 81H
33、, AL10、我们知道,MOV 指令并不能直接修改 CS、IP 的值,但事实上,我们还可以通过其他方法来达到修改 CS、IP 的目的。试编写一个程序段,使该程序段运行后, (CS)=0100H,(IP)=0000H。解:方法一、利用段间返回指令 RETF:MOV AX,0100HPUSH AX ;段基址入栈MOV AX,0PUSH AX ;偏移量入栈RETF方法二、利用 JMP 指令实现段间跳转,假设 ADDR 为双字变量:MOV WORD PTR ADDR,0 ;WORD PTR ADDR偏移量MOV WORD PTR ADDR+2, 0100H ;WORD PTR ADDR+2段基址JMP
34、 DWORD PTR ADDR 11.写出能完成下述操作的指令。(1)将立即数 1234H 送至 DS 寄存器。 (2)将存储单元 3000H 和内容送至 4000H 单元。(3)将累加器 AX 与寄存器 CX 中的内容对调。 答案: (1)MOV AX, 1234HMOV DS, AX(2) MOV AX, 3000H MOV 4000H, AX (3) XCHG AX, CX 12.编程:将数据段中以 BX 为偏移地址的连续 4 单元的内容颠倒过来。答案: MOV AL, BX XCHG AL, BX+3 MOV BX, AL MOV AL,BX+1 XCHG AL, BX+2 MOV B
35、X+1, AL 13.将 AX 寄存器清零有 4 种方法,试写出这 4 条指令。 答案:MOV AX, 00HSUB AX, AX AND AX, 00H XOR AX, AX 14.使用一条逻辑运算指令实现下列要求: (1)使 AL 高 4 位不变,低 4 位为 0。 (2)使 AL 最高位置 1,后 7 位不变。 (3)使 AL 中的 bit3、bit4 变反,其余位不变。 (4)测试判断 CL 中的 bit2、bit5、bit7 是否都为 1。答案: (1) AND AL, 0F0H (2)OR AL, 80H(3)XOR AL 18H (4)TEST AL, 0A4H 15.试分析下面
36、的程序段完成什么功能。MOV CL, 4 SHL AX, CL SHL BL, CL MOV AL, BL SHR DH, CLOR AL, DH 答案:将 AX 中间 8 位,BX 的低 4 位,DX 的高 4 位组成一个新字存放在 AX 中。16.若要将源串 100 个字节数据传送到目标串单元中去,设源串首址的偏移地址为 2500H, 目标串首址的偏移地址为 1400H,请编写程序实现以下功能。 (1)完成源串到目标串的搬移。 (2)比较两串是否完全相同,若两串相同,则 BX 寄存器内容为 0;若两串不同,则 BX 指向 源串中第一个不相同字节的地址,且该字节的内容保留在 AL 的寄存器中
37、。 答案: (1) CLDMOV CX, 100MOV SI, 2500H MOV DI, 1400H REP MOVSB(2) CLDMOV CX, 100 MOV SI, 2500MOV DI, 1400 REPE CMPSB JZ EQQ DEC SI MOV BX, SI MOV AL, SI JMP STOP EQQ: MOV BX, 0 STOP: HLT 17 设若标志寄存器原值为0A11H ,(SP)=0060H,(AL)=4。下列几条指令执行后,标志寄存器、AX、SP的值分别是多少?PUSHFLAHFXCHG AH,ALPUSH AXSAHFPOPF答:指令执行后标志寄存器的
38、值为0411H,AX=0411H ,SP=005EH。18 假 如 在 程 序 的 括 号 中 分 别 填 入 指 令 :(1) LOOP L20(2) LOOPNE L20(3) LOOPE L20试说明在三种情况下, 当程序执行完后, AX、BX 、CX、DX 四个寄存器的内容分别是什么? BEGIN: MOV AX,01MOV BX,02MOV DX,03MOV CX,04L20: INC AXADD BX,AXSHR DX,1( )答案: (1) (AX)= 5 (BX)= 16 (CX )= 0 (DX )= 0(2 ) (AX)= 3 (BX )= 7 (CX)= 2 (DX)=
39、0(3 ) (AX)= 2 (BX )= 4 (CX)= 3 (DX)= 119 变 量 N1 和 N2 均 为 2 字 节 的 非 压 缩 BCD 数 码 , 请 写 出 计 算 N1 与 N2 之 差 的 指令 序 列 。答案: MOV AX, 0MOV AL, N1SUB AL, N2AASMOV DL, ALMOV AL, N1+1SBB AL, N2+1AASMOV DH, AL20 在 已 学 的 指 令 中 , 可 实 现 累 加 器 清 0 的 单 条 指 令 有 哪 些 ? 比 较 它 们 的 功 能 。答 : ( 1) MOV AX, 0 ; 仅 将 累 加 器 清 0,
40、不 会 影 响 任 何 标 志 位( 2) SUB AX, AX ; 累 加 器 清 0 的 同 时 影 响 所 有 状 态 标 志 , 具 体 地 有 : ZF、 PF置 1, CF、 AF、 SF、 OF 均 清 0( 3) AND AX, 0 ; 将 累 加 器 清 0, ZF、 PF 置 1, CF、 OF、 SF 清 0( 4) XOR AX, AX ; 将 累 加 器 清 0, ZF、 PF 置 1, CF、 OF、 SF 清 021 已 知 ( DS) =2000H, 有 关 的 内 存 单 元 值 为 : (21000H)=00H, (21001H)=12H, (21200H)
41、=00H, (21201H)=10H, (23200H)=20H, (23201H)=30H, (23400H)=40H, (23401H)=30H, (23600H)=60H, (23601H)=30H, 符 号 COUNT 的 偏 移 地 址 为1200H。 执 行 下 列 指 令 后 , 寄 存 器 AX、 BX、 SI 的 值 分 别 是 多 少 ?MOV BX, OFFSET COUNTMOV SI, BXMOV AX, COUNTSIBX答 : 执 行 结 果 为 ( BX) =1200H, ( SI) =1000H, ( AX) =3040H。22 设 若 内 存 单 元 DAT
42、A 在 数 据 段 中 偏 移 量 为 24C0H 处 , 24C0H24C3H 单 元 中 依次 存 放 着 55H、 66H、 77H、 88H。 下 列 几 条 指 令 执 行 后 , 寄 存 器 AX、 BX、 CL、 SI、 DS的 值 分 别 是 多 少 ?MOV AX, DATALEA SI, DATAMOV CL, SILDS BX, DATA答 : 执 行 结 果 为 ( AX) =6655H, ( BX) =6655H, ( CL) =55H, ( SI) =24C0H, ( DS)=8877H。23 若 ( AX) =26D3H, ( CX) =7908H, CF=1,
43、执 行 下 列 指 令 后 , 寄 存 器 AX、 CX 的值 分 别 是 多 少 ? CF=? OF=?SAL CH, 1RCR AX, CLROL AL, 1答 : 执 行 结 果 为 ( AX) =0A64CH, ( CX) =0F208H, CF=OF=0。24 已 知 有 程 序 段 如 下 :MOV AL, 35HMOV DL, ALANDDL, 0FHANDAL, 0F0HMOV CL, 4SHR AL, CLMOV BL, 10MULBLADD AL, DL执 行 之 后 , AL 的 值 等 于 多 少 ? 该 程 序 段 完 成 了 什 么 功 能 ?答 : 程 序 段 执
44、 行 后 ( AL) =23H。 该 程 序 段 实 现 了 将 AL 中 的 1 个 组 合 BCD 码 转 换 为十 六 进 制 数 并 存 回 AL 中 的 功 能 。25 下 面 的 程 序 执 行 后 , DX、 AX 的 值 分 别 是 多 少 ?; 以 X 为 首 址 的 字 单 元 中 的 数 据 依 次 为 1234H、 5678H; 以 Y 为 首 址 的 字 单 元 中 的 数 据 依 次 为 8765H、 4321HLEA SI,XLEA DI,YMOV DX,SI 2MOV AX,XADD AX,XADC DX,SI 2CMP DX,DI2JL L2CMP AX,YJ
45、L L1JMP EXITL1: MOV AX,1JMP EXITL2: MOV AX,2EXIT:答 : 执 行 结 果 为 ( AX) =2, ( DX) =0ACF0H。26 设 VAR 字 单 元 的 值 为 x, F1 字 单 元 的 值 为 y, 试 编 程 按 以 下 要 求 给 y 赋 值 :2 x30y = 0 30x1 2 x30, 则 转 PLUS2CMP AX, 1JL MIN2 ; x1, 则 转 MIN2MOVF1, 0 ; 30x1, y=0JMP GOPLUS2: MOV F1, 2 ; y=2JMP GOMIN2: MOV F1,-2 ; y = -2 或 00
46、FEHGO: ; 后 续 处 理简 析 : 本 例 中 并 未 说 明 VAR 字 节 单 元 是 带 符 号 数 还 是 无 符 号 数 , 读 者 在 使 用 判 断 转移 指 令 时 可 任 意 选 用 。 若 当 作 带 符 号 数 , 应 使 用 JG、 JL、 JGE、 JLE 等 指 令 , 如 参 考 程 序 ;若 当 作 无 符 号 数 , 则 应 使 用 JA、 JB、 JAE、 JBE 等 指 令 。第四章 80x86 汇编语言程序设计习题与答案1、指出以下数据定义伪指令所分配的字节数(8086 系统) 。(1 ) DATA1 DB 10,?, A(2 ) DATA2 D
47、W 10 DUP(2,3 DUP(?) ,1 )(3 ) DATA3 DB HELLO,WORLD! , $(4 ) DATA4 DW DATA4解:(1)3 字节; (2) 100 字节; (3)13 字节; (4)2 字节。2、指出以下数据定义伪指令所分配的字节数(80386 系统) 。(1 ) DATA1 DF 12,34 ,56(2 ) DATA2 DF DATA2(3 ) DATA3 DQ 0,10 DUP(?)(4 ) DATA4 DT 0,1,2解:(1)18 字节; (3) 6 字节; (3)88 字节; (4)30 字节。3、指出以下指令中哪些是无效的,并说明原因。(1 ) ADDR DB $(2 ) DATA DB F0H,12H(3 ) 1_DATA DW 1234H(4 ) VAR DW VAR1 ;VAR1 为一个字节变量(5 ) MOV AX,10-VAR1 ;VAR1 为一个字变量(6 ) MOV BX,VAR2*2+1 ;VAR2 为一个字变量解:(1 )非法,地址计数器$是 32 位数;(2 )非法,以字母开头的 16 进制数应在前面加“0 ”,即应为“0F0H” ;(3 )非法,变量名非法,不能以数字开头;(4 )合法;(5 )非法,地址表达式