微机原理课后习题解答
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
微机原理习题
第一章绪论
习题与答案
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)BCD
2. 把下列十进制数转换成二进制数。
(1) 100D =
(2) 1000D =
(3) 67.21D =
解:
(1)100D = 01100100B
(2)1000D = 1111101000B
(3) 67.21D = 1000011.0011B
3. 把下列十六进制数转换成十进制数、二进制数。
(1) 2B5H =
(2) 4CD.A5H =
解:
(1) 2B5H = 693D = 0010 1011 0101B
(2) 4CD.A5H = 1229.6445D = 0100 1100 1101.1010 0101 B
4. 计算下列各式。
(1) A7H+B8H =
(2) E4H-A6H =
解:
(1) A7H+B8H = 15FH
(2) E4H-A6H = 3EH
5. 写出下列十进制数的原码、反码和补码。
(1) +89
(2) -37
解:
(1) [+89 ] 原码、反码和补码为: 01011001B
(2) [-37] 原码 = 10100101 B
[-37] 反码 = 11011010 B
[-37] 补码 = 11011011 B
6.求下列用二进制补码表示的十进制数
(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)M:1 1001101 (4)P: 1 1010000
8.请用8位二进制数写出下列字符带偶校验的ASCII码。
(1)+:0101011 (2)=: 0111101
(3)#:0100011 (4)>: 0111110
解:
(1)+:0 0101011 (2)=: 1 0111101
(3)#:1 0100011 (4)>: 1 0111110
9.叙述 CPU 中PC的作用。
解:PC是CPU中的程序计数器,其作用是提供要执行指令的地址。
第二章微处理器体系与结构
习题与答案
1. 8086/8088 CPU 由哪两大部分组成?请分别叙述它们的功能。
解:8086/8088 CPU均由两个独立的逻辑单元组成,一个称为总线接口单元BIU(Bus Interface Unit),另一个称为执行单元EU(Execution Unit)。
总线接口单元BIU取指令时,从存储器指定地址取出指令送入指令队列排队;执行指令时,根据EU命令对指定存储器单元或I/O端口存取数据。
执行单元EU任务是执行指令,进行全部算术逻辑运算、完全偏移地址的计算,向总线接口单元BIU提供指令执行结果的数据和偏移地址,并对通用寄存器和标志寄存器进行管理。
2. 8086/8088与传统的计算机相比在执行指令方面有什么不同?这样的设计思想有什么优点?
解:总线接口部分和执行部分是分开的,每当EU执行一条指令时,造成指令队列空出2个或空出一个指令字节时,BIU马上从内存中取出下面一条或几条指令,以添满他的指令队列。
这样,一般情况下,CPU在执行完一条指令后,便可马上执行下一条指令,不像以往8位CPU那样,执行完一条指令后,需等待下一条指令。
即EU从指令队列中取指令、执行指令和BIU补充指令队列的工作是同时进行的。
这样大大提高了CPU利用率,降低了系统都对存储器速度的要求。
3. 状态标志和控制标志有何不同?8086/8088的状态标志和控制标志分别有哪些?
解:8086/8088 CPU设立了一个两字节的标志寄存器,共九个标志。
其中标志位O、S、Z、A、P、C是反映前一次涉及ALU操作结果的状态标志,D、I、T是控制CPU操作特征的控制标志。
4. 8086/8088 CPU寻址存储器时,什么是物理地址?逻辑地址?它们之间有何关系?
解:8086/8088系统中每个存储单元都有一个物理地址,物理地址就是存储单元的实际地址编码。
在CPU与存贮器之间进行任何信息交换时,需利用物理地址来查找所需要的访问的存储单元。
逻辑地址由段地址和偏移地址两部分组成。
逻辑地址的表示格式为:段地址:偏移地址。
知道了逻辑地址,可以求出它对应的物理地址:物理地址=段地址×10H+偏移地址。
5. 段寄存器CS=1200H,指令指针寄存器IP=FF00H,此时,指令的物理地址为多少?指向这一物理地址的CS值和IP值是唯一的吗?
解:根据:物理地址=段地址×10H+偏移地址,指令的物理地址为21F00H。
指向这一物理地址的CS值和IP值不唯一。
6. 8086 CPU中信号和A0信号是通过怎样的组合解决存储器和外设端口的读/写的?这种组合决定了8086系统中存储器偶地址体及奇地址体之间应该用什么信号区分?怎样区分?
解:若存取一个字节的数据,总是用一个总线周期来完成该操作;若存取一个字,则依该字是规则字还是不规则字需用一个或两个总线周期来完成。
对规则字,只用一个总线周期来完成16位数据的传送,而对于非规则字则用相邻两个总线周期来完成该字的存储操作,先取
其奇地址字节(即数据的低位字节),然后存取偶地址字节。
在组成存储系统时,总是偶地址单元的数据通过AD0~AD7传送,而奇地址单元的数据通过AD8~AD15传送,即通过总线高字节传送。
信号和A0信号控制存储器读写见下表:
7.什么叫总线?为什么各种微型计算机系统中普遍采用总线结构?
答:总线是模块与模块之间传送信息的一组公用信号线。
总线标准的建立使得各种符合标准的模块可以很方便地挂在总线上,使系统扩展和升级变得高效、简单、易行。
因此微型计算机系统中普遍采用总线结构。
8.微型计算机系统总线从功能上分为哪三类?它们各自的功能是什么?
答:微型计算机系统总线从功能上分为地址总线、数据总线和控制总线三类。
地址总线用于指出数据的来源或去向,单向;数据总线提供了模块间数据传输的路径,双向;控制总线用来传送各种控制信号或状态信息以便更好协调各功能部件的工作。
9.8086/8088 CPU 分为哪两个部分?如何协调工作?
答:EU是执行部件,主要的功能是执行指令和形成有效地址。
BIU是总线接口部件,与片外存储器及I/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)等都是16位的,因而对存储器地址的处理也只能是16位操作,即8086/8088的直接寻址能力在64KB范围内。
而实际上8086/8088有20条地址线,它的最大寻址空间为1MB。
这就产生了一个矛盾,即如何用16位的地址寄存器去表示一个20位的存储器物理地址?
实际使用的解决办法是:将1MB大小的存储空间分为若干“段”,每段不超过64KB。
这
样,一个20位的物理地址就可以用“16位段基址:16位偏移量”的形式(称为逻辑地址)来表示了,其中段地址存放在8086/8088的段寄存器中。
12.8086/8088 CPU 中有几个通用寄存器?有几个变址寄存器?有几个指针寄存器?通常哪几个寄存器亦可作为地址寄存器使用?
答: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和8088外部数据总线的宽度不同将导致扩展主存储器及输入/输出接口时系统地址线和数据线连接方式的不同。
第三、其他不同的引脚定义:(1)AD15~AD0,在8086中为地址/数据复用,而在8088中AD15~AD8 改为A15~A8只作地址线用;(2)34、28号引脚定义不同。
14.8086/8088CPU工作在最小模式时:当CPU访问存储器时,要利用哪些信号?当CPU 访问外设接口时,要利用哪些信号?
答:8086/8088 CPU工作在最小模式时,若访问存储器,需用到以下信号:IO
M/、ALE、DT/、DEN、READY、BHE、W R、RD、AD0~AD15、A19/S6~A16/S3。
若访问外设,需用到R
以下信号:IO
M/、ALE、R
DT/、DEN、READY、W R、RD、AD0~AD15。
15.试指出下列运算后的各个状态标志,并说明进位标志和溢出标志的区别:
(1)1278H+3469H
答:CF=0 AF=1 ZF=0 SF=0 OF=0 PF=1
(2)54E3H-27A0H
答:CF=0 AF=0 ZF=0 SF=0 OF=0 PF=0
(3)3881H+3597H
答:CF=0 AF=0 ZF=0 SF=0 OF=0 PF=1
(4)01E3H-01E3H
答:CF=0 AF=0 ZF=1 SF=0 OF=0 PF=1
其中,进位标志CF 用于判别无符号数运算是否超出数的表示范围,而溢出标志OF 用于判别带符号数运算是否超出数的表示范围。
奇偶标志PF 只能判断结果低8 位中“1”的个数为奇数还是偶数。
16.什么是逻辑地址?什么是物理地址?它们之间有什么联系?各用在何处?
答:逻辑地址由两个16 位的部分即段基址和偏移量组成,一般在程序中出现的地址都表示为逻辑地址形式;物理地址是一个20 位的地址,它是唯一能代表存储空间每个字节单元的地址,一般只出现在地址总线上。
由于8086/8088CPU 中的寄存器只有16 位长,所以程序不能直接存放20 位的物理地址,而必须借助逻辑地址,即用两个16 位的寄存器来表示物理地址。
他们之间的关系是:物理地址=段基址*16+偏移量;另外,一个物理地址可对应多个逻辑地址。
17.设现行数据段位于存储器0B0000H~0BFFFFH 单元,DS 段寄存器内容为多少?
答: DS 段寄存器内容为0B000H。
18.在8086中,逻辑地址、偏移地址、物理地址分别指的是什么?
答:逻辑地址是在程序中对存储器地址的一种表示方法,由段基址和段内偏移地址两部分组成,都是16位的二进制代码,如1234H:0088H。
偏移地址是指段内某个存储单元相对该段首地址的差值。
物理地址是8086芯片引线送出的20位地址码,物理地址=段基址*16+偏移地址,用来指出一个特定的存储单元。
19.给定一个存放数据的内存单元的偏移地址是20C0H,(DS)=0C0E0H,求出该内存单元的物理地址。
答:物理地址:0C2EC0H。
20.8086/8088为什么采用地址/数据引线复用技术?
答:考虑到芯片成本和体积,8086/8088采用40条引线的封装结构。
40条引线引出8086/8088的所有信号是不够用的,采用地址/数据线复用引线方法可以解决这一矛盾,从逻辑角度,地址与数据信号不会同时出现,二者可以分时复用同一组引线。
21.怎样确定8086的最大或最小工作模式?
答:引线MX
MN的逻辑状态决定8086的工作模式,MX
MN引线接高电平,8086被设定为最小模式,MX
MN引线接低电平,8086被设定为最大模式。
22.8086基本总线周期是如何组成的?
答:基本总线周期由4个时钟(CLK)周期组成,按时间顺序定义为T1、T2、T3、T4。
23.在基于8086的微计算机系统中,存储器是如何组织的?存储器是如何与处理器总线连接的?BHE信号起什么作用?
答:8086为16位微处理器,可访问1M字节的存储器空间;1M字节的存储器分为两个512K字节的存储体,分别命名为偶存储体和奇存储体;偶体的数据线连接D7~D0,“体选”信号接地址线A0;奇体的数据线连接D15~D8,“体选”信号接BHE信号;A0信号有效时允许访问偶体中的低字节存储单元,BHE信号有效时允许访问奇体中的高字节存储单元,实现8086的低字节访问、高字节访问及字访问。
24.有一个由20个字组成的数据区,其起始地址为610AH:1CE7H。
试写出该数据区首
末单元的实际地址PA。
首单元地址:610A0H+1CE7H=62D87H
末单元地址:62D87H+27H=62DAEH
25.有两个16位的字31DAH、5E7FH,它们在8086系统存储器中的地址为00130H和00135H,试画出它们的存储器示意图。
地址
00130H
00131H
00132H
00133H
00134H
00135H
00136H
26.试说明8086CPU的控制引脚ALE的作用。
答: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 1234H[BX],DS (7) MOV [DI+5678H],AL (8) MOV 12[BP][DI],BH (9) POP CX (10)MOV AX,[BX+SI+10]
解:
2、指出下列指令中操作数的寻址方式(80386系统)。
(1) MOV [EBX+12H],AX (2) MOV [EBP+EDI*2],EBX (3) MOV [EBX*4],BX (4) MOV EDX,[EAX+ESI*8-12H] 解:
3、指出以下指令中,哪些指令是非法的,并说明为什么(8086系统)。
(1) PUSH 1234H (2) MOV CS,AX (3) IN AX, 300 (4) MOV AX,[DX+12] (5) MOV BX,[BX] (6) 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不能出现在中括号[]内;
(5)合法;
(6)非法,不能把立即数赋给段寄存器;
(7)合法;
(8)非法,源操作数大于0FFH,不能赋给8位寄存器AL;
(9)非法,源操作数是8位寄存器,目的操作数却是16位寄存器,不匹配;
(10)非法,LEA指令得到的是16位偏移量,但目的操作数是8位寄存器;
(11)非法,LEA指令的源操作数只能是存储器操作数;
(12)非法,指令存在歧义,无法确定传送的是字节还是字;
(13)非法,段寄存器不能参与算术运算;
(14)非法,源和目的寄存器不能同为存储器操作数;
(15)非法,在8086系统中,移位次数大于1时需要将移位次数存放到CL中;
(16)合法;
(17)非法,在8086系统中MUL指令没有双操作数的用法;
(18)非法,中断类型号大于0FFH。
4、指出以下指令中,哪些指令是非法的,并说明为什么(80386系统)。
(1) MOV AX,12[EBX][SI*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)合法;
(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)=?,(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]=12H
6、假设A、B、C、D、X、Y为字节变量,AA、BB、YY为字变量,试利用算术运算指令编写程序段,完成以下各算术运算题。
(1)计算YY←A+B*C,其中A、B、C都是无符号数;
(2)计算(AA+BB)/(C-D),商赋给X,余数赋给Y,其中AA、BB、C、D都是带符号数;(3)计算YY←(A-B)*C,其中A、B、C都是未组合BCD码。
解:
(1)MOV AL,B
MUL C
ADD AL,A
ADC AH,0
MOV YY,AX
(2)MOV AX,AA
ADD AX,BB
MOV BL,C
SUB BL,D
IDIV BL
MOV X,AL
MOV Y,AH
(3)MOV AL,A
SUB AL,B
AAS
MUL C
AAM
MOV YY, AX
7、利用移位指令编写程序段,实现以下运算。
(1)计算AX←AX*10,其中AX为无符号数;
(2)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,1
MOV BX,AX
SHL AX,1
SHL AX,1
ADD AX,BX
(2)SAL AX,1
RCL DX,1
(3)SAR DX,1
RCR AX,1
8、指出以下指令执行后,标志寄存器OF、SF、ZF、AF、PF、CF的状态。
(1)(AL)=0FFH,(BL)=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
解:
注:0表示结果为0,1表示结果为1,×表示结果不变,—表示结果不确定。
9、在8086系统下,编写实现如下功能的程序段:
(1)从地址为80H的端口中读入一个字节;
(2)如果该字节最高位为“1”,则将字节0FFH送到地址为81H的端口中,并退出程序;(3)如果该字节最高位为“0”,则转向第(1)步,继续循环扫描。
解:参考程序段:
AGAIN: IN AL, 80H
TEST AL, 80H
JZ AGAIN
MOV AL, 0FFH
OUT 81H, AL
10、我们知道,MOV指令并不能直接修改CS、IP的值,但事实上,我们还可以通过其他方法来达到修改CS、IP的目的。
试编写一个程序段,使该程序段运行后,(CS)=0100H,(IP)=0000H。
解:
方法一、利用段间返回指令RETF:
MOV AX,0100H
PUSH AX ;段基址入栈
MOV AX,0
PUSH AX ;偏移量入栈
RETF
方法二、利用JMP指令实现段间跳转,假设ADDR为双字变量:
MOV WORD PTR ADDR,0 ;WORD PTR ADDR←偏移量MOV WORD PTR ADDR+2, 0100H ;WORD PTR ADDR+2←段基址
JMP DWORD PTR ADDR
11.写出能完成下述操作的指令。
(1)将立即数 1234H 送至 DS 寄存器。
(2)将存储单元 3000H 和内容送至 4000H 单元。
(3)将累加器 AX 与寄存器 CX 中的内容对调。
答案: (1)MOV AX, 1234H
MOV 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 [BX+1], AL
13.将 AX 寄存器清零有 4 种方法,试写出这 4 条指令。
答案:MOV AX, 00H
SUB AX, AX
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.试分析下面的程序段完成什么功能。
MOV CL, 4
SHL AX, CL
SHL BL, CL
MOV AL, BL
SHR DH, CL
OR AL, DH
答案:将 AX 中间 8 位,BX 的低 4 位,DX 的高 4 位组成一个新字存放在 AX 中。
16.若要将源串 100 个字节数据传送到目标串单元中去,设源串首址的偏移地址为 2500H,目标串首址的偏移地址为 1400H,请编写程序实现以下功能。
(1)完成源串到目标串的搬移。
(2)比较两串是否完全相同,若两串相同,则 BX 寄存器内容为 0;若两串不同,则 BX 指向源串中第一个不相同字节的地址,且该字节的内容保留在 AL 的寄存器中。
答案: (1) CLD
MOV CX, 100
MOV SI, 2500H
MOV DI, 1400H
REP MOVSB
(2) CLD
MOV SI, 2500
MOV 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的值分别是多少?
PUSHF
LAHF
XCHG AH,AL
PUSH AX
SAHF
POPF
答:指令执行后标志寄存器的值为0411H,AX=0411H ,SP=005EH。
18.假如在程序的括号中分别填入指令:
(1) LOOP L20
(2) LOOPNE L20
(3) LOOPE L20
试说明在三种情况下, 当程序执行完后, AX、BX、CX、DX四个寄存器的内容分别是什么?
BEGIN: MOV AX,01
MOV BX,02
MOV DX,03
MOV CX,04
L20: INC AX
ADD BX,AX
SHR DX,1
( )
答案:(1)(AX)= 5 (BX)= 16 (CX)= 0 (DX)= 0
(2)(AX)= 3 (BX)= 7 (CX)= 2 (DX)= 0
(3)(AX)= 2 (BX)= 4 (CX)= 3 (DX)= 1
19.变量N1和N2均为2字节的非压缩BCD数码,请写出计算N1与N2之差的指令序列。
答案:MOV AX, 0
MOV AL, N1
SUB AL, N2
AAS
MOV DL, AL
MOV AL, N1+1
SBB AL, N2+1
AAS
MOV DH, AL
20.在已学的指令中,可实现累加器清0的单条指令有哪些?比较它们的功能。
答:(1)MOV AX,0 ;仅将累加器清0,不会影响任何标志位
(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清0
21.已知(DS)=2000H,有关的内存单元值为:(21000H)=00H,(21001H)=12H,(21200H)=00H,(21201H)=10H,(23200H)=20H,(23201H)=30H,(23400H)=40H,(23401H)=30H,(23600H)=60H,(23601H)=30H,符号COUNT的偏移地址为1200H。
执行下列指令后,寄存器AX、BX、SI的值分别是多少?
MOV BX,OFFSET COUNT
MOV SI,[BX]
MOV AX,COUNT[SI][BX]
答:执行结果为(BX)=1200H,(SI)=1000H,(AX)=3040H。
22.设若内存单元DATA在数据段中偏移量为24C0H处,24C0H~24C3H单元中依次存放着55H、66H、77H、88H。
下列几条指令执行后,寄存器AX、BX、CL、SI、DS的值分别是多少?
MOV AX,DATA
LEA SI,DATA
MOV CL,[SI]
LDS BX,DATA
答:执行结果为(AX)=6655H,(BX)=6655H,(CL)=55H,(SI)=24C0H,(DS)=8877H。
23.若(AX)=26D3H,(CX)=7908H,CF=1,执行下列指令后,寄存器AX、CX的值分别是多少?CF=?OF=?
SAL CH,1
RCR AX,CL
ROL AL,1
答:执行结果为(AX)=0A64CH,(CX)=0F208H,CF=OF=0。
24.已知有程序段如下:
MOV AL,35H
MOV DL,AL
AND DL,0FH
AND AL,0F0H
MOV CL,4
SHR AL,CL
MOV BL,10
MUL BL
ADD AL,DL
执行之后,AL的值等于多少?该程序段完成了什么功能?
答:程序段执行后(AL)=23H。
该程序段实现了将AL中的1个组合BCD码转换为十六进制数并存回AL中的功能。
25.下面的程序执行后,DX、AX的值分别是多少?
;以X为首址的字单元中的数据依次为1234H、5678H
;以Y为首址的字单元中的数据依次为8765H、4321H
LEA SI,X
LEA DI,Y
MOV DX,[SI+2]
MOV AX,X
ADD AX,X
ADC DX,[SI+2]
CMP DX,[DI+2]
JL L2
CMP AX,Y
JL L1
JMP EXIT
L1: MOV AX,1
JMP EXIT
L2: MOV AX,2
EXIT:……
答:执行结果为(AX)=2,(DX)=0ACF0H。
26.设VAR字单元的值为x,F1字单元的值为y,试编程按以下要求给y赋值:
2 x>30
y = 0 30≥x≥1
-2 x<1
答:一种可能的程序段实现如下:
MOV AX,VAR ;AX x
CMP AX,30
JG PLUS2 ;x>30,则转PLUS2
CMP AX,1
JL MIN2 ;x<1,则转MIN2
MOV F1,0 ;30≥x≥1,y=0
JMP GO
PLUS2:MOV F1,2 ;y=2
JMP GO
MIN2: MOV F1,-2 ;y = -2或00FEH
GO:……;后续处理
简析:本例中并未说明VAR字节单元是带符号数还是无符号数,读者在使用判断转移指令时可任意选用。
若当作带符号数,应使用JG、JL、JGE、JLE等指令,如参考程序;若当作无符号数,则应使用JA、JB、JAE、JBE等指令。
第四章 80x86汇编语言程序设计
习题与答案
1、指出以下数据定义伪指令所分配的字节数(8086系统)。
(1)DATA1 DB 10,?,‘A’
(2)DATA2 DW 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)非法,地址表达式不能是“常数-地址”;
(6)非法,地址表达式不能出现乘法。
4、假设已定义数据段如下:
DATA SEGMENT
ORG 100H
DATA1 DB 10 DUP(1,2,3)
DATA2 DW DATA1,$
DATA ENDS
且段寄存器DS已初始化为该数据段的段基址(假设段基址为1234H)。
请指出以下指令执行后,相应的寄存器中的内容。
(1)MOV AX,WORD PTR DATA1 ;(AX)=?
(2)MOV BX,DATA2 ;(BX)=?
(3)MOV CX,DATA2+2 ;(CX)=?
(4)MOV DX,OFFSET DATA2 ;(DX)=?
(5)MOV SI,SEG DATA1 ;(SI)=?
(6)MOV DI,LENGTH DATA1 ;(DI)=?
(7)MOV SP,TYPE DATA1 ;(SP)=?
(8)MOV BP,SIZE DATA2 ;(BP)=?
解:
(1)(AX)=0201H;(2)(BX)=0100H;(3)(CX)=0120H;(4)(DX)=011EH;(5)(SI)=1234H;(6)(DI)=000AH;(7)(SP)=0001H;(8)(BP)=0002H。
5、在8086系统下,编写完整程序,实现从键盘上输入8位二进制数,从显示器上显示相应的16进制数,例如从键盘上输入“00010010”,应在显示器上显示“12H”。
解:参考程序:
DATA SEGMENT
MSG1 DB 'Input binary number(ESC to exit):','$'
MSG2 DB 0AH,0DH,'Input error!',0AH,0DH,'$'
DATA ENDS
OUTPUT MACRO ASC ;定义输出一个字符的宏
MOV DL, ASC
MOV AH, 2
INT 21H
ENDM
CODE SEGMENT
ASSUME CS:CODE, DS:DATA
MAIN PROC FAR
PUSH DS
MOV AX, 0
PUSH AX
MOV AX, DATA
MOV DS, AX
AGAIN: LEA DX, MSG1
MOV AH, 9
INT 21H ;提示输入信息
MOV CX, 8 ;输入8位二进制数
MOV BL, 0
L: MOV AH, 1
INT 21H
SHL BL, 1
CMP AL, 1BH ;ESC键退出
JZ DONE
CMP AL, '0' ;输入“0”
JZ NEXT
CMP AL, '1' ;输入“1”
JNZ ERROR ;输入其他则出错
INC BL
NEXT: LOOP L
OUTPUT 0AH
OUTPUT 0DH
PUSH BX
MOV CL, 4
SHR BL, CL
CALL TRAN ;显示高4位对应的16进制数
POP BX
AND BL, 0FH
CALL TRAN ;显示低4位对应的16进制数
OUTPUT 'H'
OUTPUT 0AH
OUTPUT 0DH
JMP AGAIN
ERROR: LEA DX, MSG2
MOV AH, 9
INT 21H
JMP AGAIN
DONE: RET
MAIN ENDP
TRAN PROC FAR
CMP BL, 0AH
JB BELOW
ADD BL, 7
BELOW: ADD BL, 30H
OUTPUT BL
RET
TRAN ENDP
CODE ENDS
END MAIN
6、在8086系统下,编写完整程序,实现从键盘上输入两个4位十进制数,从显示器上显示这两个数之和,例如输入“1234”、“5678”,应在显示器上显示“6912”。
解:参考程序:
DATA SEGMENT
MSG1 DB 'Input the first number(ESC to exit):','$'
MSG2 DB 'Input the second number(ESC to exit):','$'
MSG3 DB 0AH,0DH,'Input error!Input again:','$'
DATA ENDS
OUTPUT MACRO ASC ;定义输出一个字符的宏
MOV DL, ASC
MOV AH, 2
INT 21H
ENDM
CODE SEGMENT
ASSUME CS:CODE, DS:DATA
MAIN: MOV AX, DATA
MOV DS, AX
AGAIN: LEA DX, MSG1
MOV AH, 9
INT 21H ;提示输入第一个数
CALL INPUT ;输入过程
PUSH BX
OUTPUT 0AH
OUTPUT 0DH
LEA DX, MSG2
MOV AH, 9
INT 21H ;提示输入第二个数
CALL INPUT ;输入过程
OUTPUT 0AH
OUTPUT 0DH
POP AX ;实现两个4位组合BCD码相加
ADD AL, BL ;低8位相加
DAA ;校正
MOV CL, AL ;保存至CL
ADC AH, BH ;高8位相加
MOV AL, AH ;移至AL
DAA ;校正
MOV AH, AL
MOV AL, CL
MOV BX, AX ;最后结果放在BX中
JNC NEXT
OUTPUT '1' ;如果相加结果大于9999,则显示进位“1”NEXT: PUSH BX
MOV CL, 4
SHR BH, CL
ADD BH, 30H
OUTPUT BH ;显示千位数
POP BX
PUSH BX
AND BH, 0FH
ADD BH, 30H
OUTPUT BH ;显示百位数
POP BX
PUSH BX
MOV CL, 4
SHR BL, CL
ADD BL, 30H
OUTPUT BL ;显示十位数
POP BX
AND BL, 0FH
ADD BL, 30H
OUTPUT BL ;显示个位数
OUTPUT 0AH
OUTPUT 0DH
JMP AGAIN
INPUT PROC FAR ;输入一个4位十进制数的过程
BEGIN: MOV CX, 4
MOV BX, 0
L: SHL BX, 1
SHL BX, 1
SHL BX, 1
SHL BX, 1 ;BX的值乘以16
MOV AH, 1
INT 21H ;输入
CMP AL, 1BH ;ESC键退出
JZ DONE
CMP AL, '0'
JB ERROR ;非数字,出错
CMP AL, '9'
JA ERROR ;非数字,出错
SUB AL, 30H
XOR AH, AH
ADD BX, AX ;将输入加到BX中
LOOP L
RET
ERROR: LEA DX, MSG3
MOV AH, 9
INT 21H
JMP BEGIN
DONE: MOV AH, 4CH
INT 21H
INPUT ENDP
CODE ENDS
END MAIN
7、在8086系统下,编写完整程序,实现两个32位带符号数相乘。
假设被乘数存放在以字变量MUL1开始的连续4个字节中,乘数存放在以字变量MUL2开始的连续4个字节中中,相乘结果存放在以字变量RES开始的连续8个字节中。
解:参考程序:
DATA SEGMENT
MUL1 DW 0FFFFH,0FFFFH ;被乘数
MUL2 DW 5678H,1234H ;乘数
RES DW 4 DUP(0) ;结果
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA
MAIN PROC FAR
PUSH DS
MOV AX, 0
PUSH AX
MOV AX, DATA
MOV DS, AX
MOV CX, MUL1
MOV BP, MUL1+2
MOV SI, MUL2
MOV DI, MUL2+2
TEST BP, 8000H ;被乘数是否为负数
JZ NEXT1
NOT BP ;为负数,则取反加1 NOT CX
ADD CX, 1
ADC BP, 0
NEXT1: TEST DI, 8000H ;乘数是否为负数JZ NEXT2
NOT SI ;为负数,则取反加1 NOT DI
ADD SI, 1
ADC DI, 0
NEXT2: MOV AX, SI ;相乘过程
MUL CX
MOV RES, AX
MOV RES+2, DX
MOV AX, SI
MUL BP
ADD RES+2, AX
ADC RES+4, DX
MOV AX, DI
MUL CX
ADD RES+2, AX
ADC RES+4, DX
MOV AX, DI
MUL BP
ADD RES+4, AX
ADC RES+6, DX
MOV AX, MUL1+2
XOR AX, MUL2+2 ;判断被乘数和乘数是否同号
JNS DONE ;同号,则结果为正数,无须修改结果
NOT RES ;不同号,则结果为负数,须取反加1
NOT RES+2
NOT RES+4
NOT RES+6
ADD RES, 1
ADC RES+2, 0
ADC RES+4, 0
ADC RES+6, 0
DONE: RET
MAIN ENDP
CODE ENDS
END MAIN
8、在8086系统下,编写完整程序,找出字节数组ARRAY中的最大值和最小值。
假设ARRAY 的长度为100个字节,每个字节为一个无符号数,程序执行后最大值将存放到字节变量MAX 中,最小值则存放到字节变量MIN中。
解:参考程序:
DATA SEGMENT
ARRAY DB 100 DUP(?);字节数组
MAX DB ? ;最大值
MIN DB ? ;最小值
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA
MAIN PROC FAR
PUSH DS
MOV AX, 0
PUSH AX
MOV AX, DATA
MOV DS, AX
LEA SI, ARRAY
CLD
MOV BH, 0 ;存放临时最大值的寄存器
MOV BL, 0FFH ;存放临时最小值的寄存器
MOV CX, 100
AGAIN: LODSB
CMP AL, BH
JNA NEXT1
MOV BH, AL ;如果当前数值比临时最大值大,则代替
NEXT1: CMP AL, BL
JNB NEXT2
MOV BL, AL ;如果当前数值比临时最小值小,则代替
NEXT2: LOOP AGAIN
MOV MAX, BH
MOV MIN, BL
RET
MAIN ENDP
CODE ENDS
END MAIN
9、在8086系统下,编写完整程序,将字节数组ARRAY中的所有数据往高地址的方向移动一位,即原来存放在ARRAY中的字节移动到ARRAY+1中,原来存放在ARRAY+1中的字节移动到ARRAY+2中,……,依此类推。
假设ARRAY的长度为100个字节。
解:可利用MOVSB指令实现移位,但应该注意,必须从串尾开始移动,因为假如直接从串头开始,将串头移到第二个数,那么第二个数将被覆盖。
为使程序能从串尾开始移动,可令方向标志位DF=1。
参考程序:
DATA SEGMENT
ARRAY DB 100 DUP(?), ?
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA
MAIN PROC FAR
PUSH DS
MOV AX, 0
PUSH AX
MOV AX, DATA
MOV DS, AX
MOV ES, AX
LEA SI, ARRAY+99 ;SI指向源串尾
LEA DI, ARRAY+100 ;DI指向新串尾
STD ;DF=1,串尾先移动
MOV CX, 100
REP MOVSB ;循环移动
RET
MAIN ENDP
CODE ENDS
END MAIN
10、在8086系统下,编写在长字符串L_STR中查找短字符串S_STR的完整程序,如果找到匹配的字符串,则将字节变量RES置0FFH,否则置0。
例如,在字符串“ABABCD”中可找到字符串“ABC”,则RES=0FFH。
解:参考程序:。