微机原理习题答案1234章
更新时间:2024-06-09 05:34:01 阅读量: 综合文库 文档下载
- 微机原理与接口技术推荐度:
- 相关推荐
微机原理与接口技术
第1章 数制与码制
1. 将下列十进制数转换成二进制数: (1)58;(2)67.625; (3)5721; 解:(1) 58D = 0011 1010B (2) 67.625D = 0100 0011.1010B (3) 5721D = 0001 0110 0101 1001B 2. 将二进制数变换成十六进制数: (1)1001 0101B;
(2)11 0100 1011B; (3)1111 1111 1111 1101B;
(6)0100 0000 0001B
(4)0100 0000 10101B;(5)0111 1111B; 解: (1)1001 0101B = 95H
(2)11 0100 1011B = 34BH (3)1111 1111 1111 1101B = FFFDH (4)0 1000 0001 0101B = 815H (5)0111 1111B = 7FH (6)0100 0000 0001B = 401H
3. 将十六进制数变换成二进制数和十进制数:
(1)78H; (2)0A6H; (3)1000H; (4)0FFFFH 解:(1)78H = 120D = 0111 1000B (2)0A6H = 166D = 1010 0110B
(3)1000H = 4096D = 0001 0000 0000 0000H (4)0FFFFH = 65535D = 1111 1111 1111 1111B 4. 将下列十进制数转换成十六进制数: (1)39; (2)299.34375; (3)54.5625 解:(1)39D = 27H
(2)299.34375D = 12B.58H (3)54.5625D = 36.9H
5. 将下列二进制数转换成十进制数:
- 0 -
微机原理与接口技术
(1)10110.101B; (2)10010010.001B; (3)11010.1101B 解:(1)10110.101B = 22.625D (2)10010010.001B = 146.125D (3)11010.1101B = 26.8125D 6. 计算(按原进制运算):
(1)10001101B+11010B; (2)10111B+11100101B; (3)1011110B-1110B; (4)124AH+78FH; (5)5673H+123H; (6)1000H-F5CH; 解:(1)10100111B
(2) 11111100B (3)1010000B (4)19D9H (5)5796H (6)A4H
7. 已知a=1011B, b=11001B, c=100110B, 按二进制完成下列运算,并用十进制运算检查
计算结果:
(1)a+b; (2)c-a-b; (3)a×b; (4)c÷b 解:a=1011B=11D b=11001B=25D c=100110B =38D
(1)100100B = 36D (2)10B = 2D
(3)1 0001 0011B=275D (4)1B 余1101B= 13D
8. 已知a=00111000B, b=11000111B, 计算下列逻辑运算: (1)a AND b; (2)a OR b; (3)a XOR b; (4)NOT a 解:(1)00000000B (2)11111111B (3)11111111B (4)11000111B
9. 设机器字长为8位,写出下列各数的原码和补码:
- 1 -
微机原理与接口技术
(1)+1010101B;(2)-1010101B;(3)+1111111B; (4)-1111111B;(5)+1000000B;(6)-1000000B 解:(1)原01010101B 补01010101B (2)原11010101B 补10101011B (3) 原01111111B 补01111111B (4) 原11111111B 补10000001B (5) 原01000000B 补01000000B (6) 原11000000B 补11000000B
10. 写出下列十进制数的二进制补码表示(设机器字长为8位): (1)15;(2)-1;(3)117;(4)0; (4)-15;(5)127;(6)-128;(7)80 解:(1) (00001111B)补 (2) (11111111B)补 (3) (01110101B)补 (4) (00000000B)补 (5) (11110001B)补 (6) (01111111B)补 (7) (10000000B)补 (8) (01010000B)补
11. 设机器字长为8位,先将下列各数表示成二进制补码,然后按补码进行运算,并用十进
制数运算进行检验:
(1)87-73;(2)87+(-73);(3)87-(-73);
(4)(-87)+73;(5)(-87)-73;(6)(-87)-(-73); 解:(1)1110B=14D (2)00001110B 进位舍弃 (3)10100000B=-96D 溢出 (4)11110010B=-14D (5)01100000B=96D 溢出
- 2 -
微机原理与接口技术
(6)11110010B=-14D
12. 已知a,b,c,d为二进制补码:a=00110010B, b=01001010B, c=11101001B, d=10111010B,
计算:
(1)a+b;(2)a+c;(3)c+b;(4)c+d; (5)a-b;(6)c-a;(7)d-c;(8)a+d-c 解:(1)01111100B (2)00011011B (3)00110011B (4)10100011B (5)11101000B (6)10110111B (7)11010001B (8)11B
13. 设下列四组为8位二进制补码表示的十六进制数,计算a+b和a-b,并判断其结果是否
溢出:
(1)a=37H, b=57H; (2)a=0B7H, b=0D7H; (3)a=0F7H, b=0D7H; (4)a=37H, b=0C7H 解:(1)a+b=8EH溢出,a-b=E0H未溢出 (2)8EH未溢出,E0H未溢出
(3)CEH未溢出,20H未溢出 (4)FEH未溢出70H未溢出
14. 求下列组合BCD数的二进制和十六进制表示形式: (1)3251(2)12907(3)2006 解:(1)0011 0010 0101 0001B = 3251H (2)0001 0010 1001 0111B = 12907H (3)0010 0000 0000 0110B = 2006H
15. 将下列算式中的十进制数表示成组合BCD码进行运算,并用加6/减6修正其结果: (1)38+42;(2)56+77;(3)99+88;(4)34+69;
- 3 -
微机原理与接口技术
(5)38-42;(6)77-56;(7)15-76;(8)89-23
解:(1) 0011 1000B + 0100 0010B = 0111 1010B 低BCD码位需要加6修正 0111 1010B + 0000 0110B = 1000 0000B = 80BCD
(2) 0101 0110B + 0111 0111B = 1100 1101B 高、低BCD码位都需要加6修正 1100 1101B + 0110 0110B = 0001 0011 0011B=133BCD
(3) 1001 1001B+1000 1000B = 0001 0010 0001B 高、低BCD码位都需要加6修正
0001 0010 0001B +0110 0110B = 0001 1000 0111B=187BCD
(4) 0011 0100B + 0110 1001B = 1001 1101B 低BCD码位需要加6修正
1001 1101B + 0000 0110B = 1010 0011B 修正结果使高BCD码位需要加6修正 1010 0011B +0110 0000B = 0001 0000 0011B = 103BCD
(5) 00111000B-01000010B =(-1)1111 0110B 高 BCD码位需要减6修正 (-1)1111 0110B -0110 0000B =(-1)1001 0110B=-100+96=-4BCD (6)01110111B-01010110B = 0010 0001B = 21BCD
(7) 00011001B-01110110B =(-1)1001 1111B 高、低BCD码位都需要减6修正 (-1)1001 1111B -01100110B =(-1)0011 1001B = -100+39 = -61BCD (8)10001001B-00100011B = 0110 0110B = 66BCD
16. 将下列字符串表示成相应的ASCII码(用十六进制数表示): (1)Example 1;(2)XiDian University;(3)-108.652; (4)How are you?;(5)Computer(6)Internet Web 解:(1)45H,78H,61H,6DH,70H,6CH,65H,20H,31H
(2) 58H,69H,44H,69H,61H,6EH,20H,55H,6EH,69H,76H,65H,72H,73H,69H,74H,79H (3)2DH,31H,30H,38H,2EH,36H,35H,32H
(4)48H,6FH,77H,20H,61H72H,65H,20H79H,6FH,75H (5)43H,6FH,6DH,70H,75H,74H,65H,72H
(6)49H,6EH,74H,65H72H,6EH,65H,74H,20H,57H,65H,62H 17. 将下列字符串表示成相应的ASCII码(用十六进制数表示): (1)Hello(2)123
- 4 -
微机原理与接口技术
解:(1)48H,65H,6CH,6CH,6FH (2)31H,32H,33H,0DH,34H,35H,36H
(3)41H,53H,43H,49H,49H (4)54H,68H,65H,20H,6EH,75H,6DH,62H,65H,72H
- 5 -
微机原理与接口技术
第2章 8086 CPU结构与功能
1. 微处理器内部结构由哪几部分组成?阐述各部分的主要功能。 解:微处理器内部结构由四部分组成:
(1)算术逻辑运算单元ALU:完成所有的运算操作; (2)工作寄存器:暂存寻址信息和计算过程中的中间结果;
(3)控制器:完成指令的读入、寄存和译码,并产生控制信号序列使ALU完成指定操
作;
(4)I/O控制逻辑:处理I/O操作。
2. 微处理器级总线有哪几类?各类总线有什么作用? 解:微处理器级总线有三类: (1)数据总线:传送信息; (2)地址总线:传送地址码; (3)控制总线 传送控制信号。
3. 为什么地址总线是单向的,而数据总线是双向的?
解:地址码只能由CPU生成。而数据需要在CPU和存储器之间传输。 4. 8086/8088微处理器内部有哪些寄存器?其主要作用是什么?
解:8086CPU内部有14个16位寄存器,其中8个通用寄存器(4数据寄存器AX、BX、
CX、DX,4地址指针/变址寄存器SI、DI、SP、BP),4个段寄存器(CS、DS、ES、SS),2个控制寄存器(指令指针IP,微处理器状态字PSW)。
应该注意的是:可以在指令中用作为地址指针的寄存器有:SI、DI、BP和BX;在微处理器状态字PSW中,一共设定了9个标志位,其中6个标志位用于反映ALU前一次操作的结果状态(CF,PF,AF,ZF,SF,OF),另3个标志位用于控制CPU操作(DF,IF,TF)。
5. 如果某微处理器有20条地址总线和16条数据总线:
(1)假定存储器地址空间与I/O地址空间是分开的,则存储器地址空间有多大? (2)数据总线上传送的有符号整数的范围有多大? 解:(1)存储器地址空间为:220?1MB
15 (2)有符号数范围为: ?2~2?1, 即 -32768~32767
- 6 -
15微机原理与接口技术
6. 将十六进制数62A0H与下列各数相加,求出其结果及标志位CF、AF、SF、ZF、OF
和PF的值:
(1) 1234H;(2) 4321H;(3) CFA0H;(4) 9D60H 解:(1) 74D4H CF=0 AF=0 SF=0 ZF=0 OF=0 PF=1 (2) A5C1H CF=0 AF=0 SF=1 ZF=0 OF=1 PF=0 (3) 3240H CF=1 AF=0 SF=0 ZF=0 OF=0 PF=0 (4) 0000H CF=1 AF=0 SF=0 ZF=1 OF=0 PF=1
7. 从下列各数中减去4AE0H,求出其结果及标志位CF、AF、SF、ZF、OF和PF的值: (1)1234H;(2)5D90H;(3)9090H;(4)EA04H 解:(1) C754H CF=1 AF=0 SF=1 ZF=0 OF=0 PF=0 (2) 12B0H CF=0 AF=0 SF=0 ZF=0 OF=0 PF=0 (3) 45B0H CF=0 AF=0 SF=0 ZF=0 OF=1 PF=0 (4) 9F24H CF=0 AF=0 SF=1 ZF=0 OF=0 PF=1 9. 写出下列存储器地址的段地址、偏移地址和物理地址: (1)2134:10A0;(2)1FA0:0A1F;(3)267A:B876 解:物理地址=段地址*10H+偏移地址
(1)段地址:2134H,偏移地址:10A0H,物理地址:223E0H (2)段地址:1FA0H,偏移地址:0A1FH,物理地址:2041FH (3)段地址:267AH,偏移地址:B876H,物理地址:32016H
10. 给定一个数据的有效地址为2359H,并且(DS)=490BH,求该数据的物理地址。 解:物理地址=段地址*10H+偏移地址
物理地址=490BH +2359H = 4B409H
11. 如果在一个程序段开始执行之前,(CS)=0A7F0H,(IP)=2B40H,求该程序段的第
一个字的物理地址。
解:物理地址=段地址*10H+偏移地址
物理地址=CS*10H+IP = AAA40H
12. IBM PC有哪些寄存器可用来指示存储器的地址? 解:变址寄存器SI,DI,堆栈指针SP,BP,另外还有BX。
- 7 -
微机原理与接口技术
第3章 8086CPU指令系统
1. 写出完成下列要求的变量定义语句:
(1)在变量var1中保存6个字变量:4512H,4512,-1,100/3,10H,65530; (2)在变量var2中保存字符串:’BYTE’, ’word’, ’WORD’; (3)在缓冲区buf1中留出100个字节的存储空间;
(4)在缓冲区buf2中,保存5个字节的55H,再保存10个字节的240,并将这一过程
重复7次;
(5)在变量var3中保存缓冲区buf1的长度;
(6)在变量pointer中保存变量var1和缓冲区buf1的偏移地址。 解:var1
var2 buf1 buf2 var3
DW DB DB DB DB
4512H,4512,-1,100/3,10H,65530 ’BYTE’,’word’,’WORD’ 100 DUP(?)
7 DUP(5 DUP(55H),10 DUP(240)) LENGTH buf1
var1,buf1 (或者pointer DW OFFSET var1,OFFSET buf1)
pointer DW
2. 设变量var1的逻辑地址为0100:0000,画出下列语句定义的变量的存储分配图: var1 DB 12,-12,20/6,4 DUP(0,55H) var2 DB ‘Assemble’
var3 DW ‘AB’, ‘cd’, ‘E’ var4 DW var2 var5 DD var2 解:
- 8 -
微机原理与接口技术
3. 指令正误判断,对正确指令写出源和目的操作数的寻址方式,对错误指令指出原因(设
VAR1, VAR2为字变量, L1为标号): (1)MOV SI,100 (3)MOV AX, [BX] (5)MOV BP, AL (7)MOV CS, AX (9)MOV [BX][SI], 1 (11)ADD AX, LENGTH VAR1 (13)SUB [DI], 78H (15)PUSH 100H (17)XCHG AX, ES (19)JMP L1+5 (21)SHL BL, 2 (23)MUL CX
(25)ADC CS:[0100], AH 解:(1)MOV SI,100
(2)MOV BX,VAR1[SI] (4)MOV AL, [DX] (6)MOV VAR1, VAR2 (8)MOV DS, 0100H (10)MOV AX, VAR1+VAR2 (12)OR BL, TYPE VAR2 (14)MOVS VAR1, VAR2 (16)POP CS (18)MOV DS, CS (20)DIV AX, 10 (22)MOV AL, 15+23 (24)XCHG CL, [SI] (26)SBB VAR1-5,154
正确。源:立即数寻址, 目的:寄存器寻址 正确。源:寄存器相对寻址, 目的:寄存器寻址 正确。源:寄存器间接寻址,目的:寄存器寻址
错误。寄存器间接寻址时,DX, AX, CX不能作地址寄存器 错误。操作数类型不一致
- 9 -
(2)MOV BX,VAR1[SI] (3)MOV AX,[BX] (4)MOV AL,[DX] (5)MOV BP,AL
微机原理与接口技术
(6)MOV VAR1,VAR2 (7)MOV CS,AX
错误。两存储单元之间不能用MOV指令传送数据 错误。CS不能为目的操作数
错误。目的操作数为段寄存器时,源操作数不能为立即数 错误。指令类型不定。
错误。MOV指令中不能完成加法运算
(8)MOV DS,0100H (9)MOV [BX][SI],1
(10)MOV AX,VAR1+VAR2
(11)ADD AX,LENGTH VAR1 正确。源:立即数寻址。目的:寄存器寻址 (12)OR
BL,TYPE VAR2
正确。源:立即数寻址。目的:寄存器寻址 错误。指令类型不定
(13)SUB [DI],78H
(14)MOVS VAR1,VAR2 正确。目的、源均为隐含寻址。操作数仅指出操作数类型 (15)PUSH 100H (16)POP
错误。将常数压入堆栈,要通过寄存器来实现
错误。目的操作数不能为CS
CS
(17)XCHG AX,ES (18)MOV DS,CS (19)JMP L1+5 (20)DIV (21)SHL
错误。XCHG指令的操作数不能是段寄存器 错误。MOV指令不能从段寄存器到段寄存器 正确。段内直接转移
错误。指令格式错误。
错误。移位指令的移位数为1或者CL
AX,10 BL,2
(22)MOV AL,15+23 正确。源:立即数寻址,目的:寄存器。编译时就处理为38 (23)MUL
CX
正确。源:寄存器寻址,目的:寄存器寻址
(24)XCHG CL,[SI] 正确。源:寄存器间接寻址,目的:寄存器寻址
(25)ADC CS:[0100],AH 正确。源:寄存器寻址,目的: 直接寻址(数据在代码段中) (26)SBB
VAR1-5,154 正确。源:立即数寻址,目的:直接寻址。
4. 说明下列指令对的区别:
(1)MOV AX,VAR1 (2)MOV AX,VAR2
与 MOV AX,OFFSET VAR1 与 LEA AX,VAR2
(3)MOV AL,LENGTH VAR1 与 MOV AL,SIZE VAR1 (4)MOV AL,ES: [DI] CMP AL, [SI] 与 CMPSB (5)SHR AL,1 (6)SHR AL,1
与 SAR AL,1 与 ROR AL,1
- 10 -
微机原理与接口技术
(7)ROL BX,1 解:(1)MOV
MOV (2)MOV
与 RCL BX,1
AX,VAR1 把变量VAR1对应地址单元中的一个字送入AX AX,OFFSET VAR1 把VAR1的有效地址的偏移地址送入AX AX,VAR2 把变量VAR2对应地址单元中的一个字送入AX
LEA AX,VAR2 把VAR2的有效地址的偏移地址送入AX (3)MOV AL,LENGTH VAR1 把变量VAR1的长度送入AL
MOV AL,SIZE VAR1 把变量VAR1的大小送入AL (4)MOV
AL,ES:[DI]
把以ES为段地址,DI为偏移地址的一个字节送入AL,
并与以SI内容为偏移地址的一个字节作比较,改变标志寄 存器内容。(相当于作ES:(DI)与(DS: (SI)内容比较)
CMPSB
对字符串中的一字节比较。寻址方式隐含。源串的地址由 DS:SI指定,目的串的地址由ES:DI指定。(相当于作 DS: (SI)与ES:(DI)内容比较)
(5)SHR AL,1 AL逻辑右移1位,最高位移入0, 最低位移入CF。
SAR AL,1 AL算术右移1位,以最高位内容移入,最低位移入CF, 其余各位
右移一位。
(6)SHR AL,1 AL逻辑右移1位,最高位移入0, 最低位移入CF。 ROR AL,1
AL的各位构成环形移位,右移一位,最低位内容同时移入到CF和 最高位。
(7)ROL BX,1 BX各位构成环形移位,左移一位,最高位内容同时移入到CF和
最低位。
RCL BX,1 BX和CF构成环形移位,左移一位,CF内容移入到最低位,最 高位移入CF。
CMP AL,[SI]
5. 写出下列转移指令的寻址方式(设L1为标号,VAR1为字型变量,DVAR1为双字型变量): (1)JMP L1 (3)JNZ L1 (5)JG L1
(2)JMP NEAR L1 (4)JMP BX (6)JMP VAR1[SI]
- 11 -
微机原理与接口技术
(7)JMP FAR PTR L1 (8)JMP DVAR1
解:(1)JMP L1 段内直接寻址 (2)JMP NEAR PTR L1 段内直接寻址 (3)JNZ
L1 段内直接寻址
(4)JMP BX
段内间接寻址
段内间接寻址
(5)JG L1 段内直接寻址 (6)JMP VAR1[SI]
(7)JMP FAR PTR L1 段间直接寻址 (8)JMP DVAR1 段间间接寻址
6. 设(DS)=2000H,(BX)=0100H,(SI)=0002H,(20100)=3412H,(20102)=7856H,
(21200)=4C2AH,(21202)=65B7H,求下列指令执行后AX寄存器的内容: (1)MOV AX,1200H; (2)MOV AX,BX; (3)MOV AX, [1200H]; (4)MOV AX, [BX]; (5)MOV AX,1100[BX];(6)MOV AX, [BX][SI]; (7)MOV AX,1100[BX][SI]
解:(1)1200H (2) 0100H (3)4C2AH (4)3412H (5)4C2AH (6)7856H (7)65B7H
7. 执行下列指令后,DX寄存器中的内容是多少?
TABLE PYL ??
MOV BX,OFFSET TABLE ADD BX,PYL MOV DX,[BX]
解:DX = 10FFH 由-16(FFF0H)的高8位和10000(2710H)的低8位构成 8. 如果堆栈的起始地址为2200:0000,栈底为0100H,(SP)=00A8H,求
(1)栈顶地址; (2)SS的内容;
(3)再存入数据5678H,3AF2H后,SP的内容。
DW 25,36,-1,-16,10000,13 DW 7
解:栈顶地址 00A8H, SS = 2200H, 再存入2个字后,SP = 00A4H 9. 设已用伪指令EQU定义了4个标识符:
N1 EQU 2100 N2 EQU 10
- 12 -
微机原理与接口技术
N3 EQU 20000 N4 EQU 25000
下列指令是否正确?并说明原因。
(1)ADD AL,N1-N2; (3)SUB BX,N4-N3; (5)ADD AL,N2;
(2)MOV AX,N3+N4; (4)SUB AH,N4-N3-N1; (6)MOV AH,N2*N2
解:(1)错误。N1-N2=2090>255 (2)正确 (3)正确 (4)错误。N4-N3-N1=2900>255 (5)正确 (6)正确 10. 按下列要求写出指令:
(1)将AX寄存器的低4位清零,其余位不变; (2)将BX寄存器的低4位置1,其余位不变; (3)将AL寄存器的低4位保持不变,高4位取反;
(4)测试BX中的位1和位2,当这两位同时为0时将AL置0FFH,否则AL清零; (5)测试BX中的位1和位2,当这两位有一位为0时将AL置0FFH,否则AL清零; (6)将AL中保存的字母ASCII码变换成相应的大写字母的ASCII码; (7)将AL中保存的字母ASCII码变换成相应的小写字母的ASCII码; (8)将AX中的各位取反;
(9)将DX中的低7位取反,高9位不变;
(10)将CX中的低8位与高8位互换。
解:(1)AND AX,0FFF0H (2)OR BX,000FH (3)XOR
AL,0F0H
BX,06H
(5)
MOV
AX,BX AX,06H
(4) TEST
JZ ZERO AND
MOV
AL,00H
XOR AX,06H JZ OVER
MOV
AL,0FFH
JMP OVER
ZERO: MOV AL,0FFH
OVER: OVER:
- 13 -
微机原理与接口技术
(6)AND AL,5FH 或者:
CMP
JL CMP JG
AL,61H
OVER (无需变换或不是字母) AL,7AH
OVER (不是字母)
AND AL,5FH 或 SUB AL,20H OVER:
(7)OR AL,20H 或者:
CMP
JL CMP JG
AL,41H
OVER (不是字母) AL,5AH
OVER (无需变换或不是字母)
OR AL,20H 或 ADD AL,20H OVER:
(8)XOR AX,0FFFFH (9)XOR DX,007FH (10)XCHG CH,CL 11. 写出完成下述功能的程序段:
(1)传送40H到AL寄存器; (2)将AL的内容乘以2; (3)传送16H到AH寄存器; (4)AL的内容加上AH的内容。 计算最后结果(AL)=?
或者
NOT
AX
- 14 -
微机原理与接口技术
解:(1)MOV AL,40H (2)SHL AL,1 (3)MOV AH,16H (4)ADD AL,AH AL=96H
12. 写出完成下述功能的程序段:
(1)从缓冲区BUF的0004偏移地址处传送一个字到AX寄存器; (2)将AX寄存器的内容右移2位;
(3)将AX内容与BUF的0006偏移地址处的一个字相乘; (4)相乘结果存入BUF的0020H偏移地址处(低位在前)。 解: (1) LEA SI, BUF
MOV
AX, [SI+4] AX,1 AX,1
WORD PTR 6[SI] 20H[SI],AX 22H[SI],DX
(2) SHR
SHR
(3) MUL (4) MOV
MOV
13. 设(BX)=11001011B,变量VAR的内容为00110010B,求下列指令单独执行后BX的内
容:
(1)XOR BX,VAR; (3)OR BX,VAR;
(2)AND BX,VAR; (4)XOR BX,11110000B; (6)TEST BX,1
(5)AND BX,00001111B; 解:(1)00F9H (2)0002H (3)00FBH (4)003BH (5)000BH (6)00CBH
- 15 -
微机原理与接口技术
14. 设(DX)=10111011B,(CL)=3,(CF)=1,求下列指令单独执行后DX的内容:
(1)SHR DX,1; (2)SAR DX,CL; (3)SHL DX,CL; (4)SHL DX,1; (5)ROR DX,CL; (6)ROL DL,CL; (7)SAL DH,1; (8)RCL DX,CL; (9)RCR DL,1 解:DX= 0000 0000 1011 1011B CF=1 CL=3 (1)SHR
DX,1
DX逻辑右移1
0000 0000 0101 1101B =
005DH
(2)SAR DX,CL (3)SHL DX,CL (4)SHL DX,1 (5)ROR (6)ROL
DX算术右移3 DX逻辑左移3 DX逻辑左移1
0000 0000 0001 0111B = 0000 0101 1101 1000B = 0000 0001 0111 0110B =
0017H 05D8H 0176H
6017H 00DDH
DX,CL DL,CL
DX循环右移3 DL循环左移3
0110 0000 0001 0111B = 0000 0000 1101 1101B =
(7)SAL DH,1 (8)RCL DX,CL (9)RCR
DH算术左移1 0000 0000 1011 1011B = 00BBH
05DCH 00DDH
DX带进位循环左移3 0000 0101 1101 1100B = 0000 0000 1101 1101B =
DL,1 DL带进位循环右移1
15. 选择题(各小题只有一个正确答案)
(1)执行下列三条指令后:
MOV SP,1000H PUSH AX CALL BX
a. (SP)=1000H; c. (SP)=1004H;
b. (SP)=0FFEH; d. (SP)=0FFCH;
(2)要检查寄存器AL中的内容是否与AH相同,应使用的指令为:
a. AND AL, AH
b. OR AL, AH
c. XOR AL, AH d. SBB AL, AH
(3)指令JMP NEAR PTR L1与CALL L1(L1为标号)的区别在于:
a. 寻址方式不同; c. 目的地址不同;
b. 是否保存IP的内容; d. 对标志位的影响不同。
解:(1)D PUSHU AX则AX入栈,SP=0FFEH;CALL BX则IP入栈,SP=0FFCH
- 16 -
微机原理与接口技术
(2)C (3)B
异或,若相同,则AL=0,ZF=1。
16. 寄存器DX:AX组成32位数,DX为高位,编写程序段实现:
(1)DX:AX右移3位,并将移出的低3位保存在CL中; (2)DX:AX左移3位,并将移出的高3位保存在CL中; 解:(1)移出的3位应该按时序移入CL中。
XOR CL,CL MOV BL,3
L1: SHR DX,1
RCR AX,1 RCL CL,1 DEC BL JNZ L1
(2)移出的3位应该按时序移入CL中。
XOR CL,CL MOV BL,3
L1: SHL AX,1
RCR DX,1 RCR CL,1 DEC BL JNZ L1
17. 编写程序段实现将BL中的每一位重复4次,构成32位的双字DX:AX,例如当BL
=01011101B时,则得到的(DX)=0F0FH,(AX)=0FF0FH。
解:算术右移时,移入的值就是最高位本身,这样可以使位内容重复,利用这一点可以实现题目的要求。
XOR XOR MOV
DX,DX AX,AX CX,4
- 17 -
微机原理与接口技术
L1: SHR
RCR SAR SAR SAR LOOP MOV
BL,1 AX,1 AX,1 AX,1 AX,1 L1 CX,4 BL,1
L2: SHR
RCR SAR SAR SAR LOOP
DX,1 DX,1 DX,1 DX,1 L2
18. 字变量VAR1中保存有小于38250的16位无符号数,编写程序段实现VAR1÷150,并
进行四舍五入操作,将商保存在字节变量VAR2中。
解:根据题意,38250÷150=255,因此商不会超过255,可以用一个字节表示。
a÷b的四舍五入操作可以通过判断除后余数实现:余数大于等于除数的一半,则商加1;否则不用加1。但这种方法用汇编语言编程实现时比较复杂,这里介绍另外一种方法:设a÷b的四舍五入后的结果为c,用『』表示取整数操作,则
b???a??a?2? c???0.5??bb??????这种方法是在除法操作之前,在被除数上加上除数的一半,这样除法操作后得到的值就是考虑了四舍五入的商。 VAR1
DW 12345
DB ?
DB 150
VAR2
DATAA
MOV AX,VAR1
- 18 -
微机原理与接口技术
XOR BX,BX MOV BL,DATAA SHR BX,1 ADD AX,BX DIV DATAA
MOV VAR2,AL
19. 有一组无符号的16位数据保存在BUFFER中,前两个字节存放数据的个数,编程实现
按下式进行滤波处理:
1?x(k)?x(k?1)?x(k?2)?3y(k)?x(k)y(k)?解:滤波结果保存在FILT中。
BUFFER DW 0CH
k?2k?2
DW 33H, 18H, 1BH, 06H, 33H, 08H DW 3H, 6H, 0FH, 51H, 05H, 0CH
LEA SI,BUFFER LEA DI,FILT MOV CX,[SI] MOV [DI],CX ADD SI,2 ADD DI,2 XOR DX,DX MOV AX,[SI] MOV [DI],AX MOV BX,2[SI] MOV 2[DI],BX ADD SI,4
- 19 -
FILT DW 100H DUP(?)
微机原理与接口技术
ADD DI,4 DEC CX DEC CX ADD AX,BX ADC DX,0 MOV BX,3 L1:
ADD AX,[SI] ADC DX,0 PUSH DX PUSH AX DIV BX MOV [DI],AX POP AX POP DX SUB AX, [SI-4] SUBB DX,0 ADD DI,2 ADD SI,2 LOOP L1
20. 在由字符串构成的缓冲区BUFFER中,前2个字节存放字符个数,后续每个字节存放
一个字符的ASCII码。编写程序实现将字符串‘2004’替换成‘2006’。 解:在数据段中定义:
BUFFER DW 74
DB ‘This year is 2004. In 2004, we have a plan for reducing annual expensive 10%’ DEST DB ‘2004’
在代码段中编写程序段:
- 20 -
微机原理与接口技术
CLD LEA SI, BUFFER MOV CX,[SI] ADD SI,2 LEA
DI,DEST
L1: PUSH SI PUSH DI PUSH
CX
MOV CX,4 REPZ SCASB JNZ
L2
MOV BYTE PTR [SI-1],’6’L2: POP CX POP DI POP SI INC SI INC
DI
LOOP L1
21. 定义有下列宏指令:
WAGS MACRO S1,S2,S3 SUB AX,AX MOV DX,AX ADD AX,S1 ADD AX,S2 ADC DX,0 ADD AX,S3
ADC DX,0
21 -
-微机原理与接口技术
ENDM
当采用宏调用指令“WAGS 60000,25000,3000”时,执行后DX= AX= 。 解:宏指令WAGS完成的功能为S1+S2+S3,结果放在DX:AX中。所以,调用“WAGS 60000,25000,3000”时,其结果为
DX=0001H ,AX=57C0H 22. 对上题定义的宏指令,如果采用宏调用指令“WAGS BX,CX,SI”时,写出宏展开形式。 解:调用“WAGS BX,CX,SI”时,宏展开形式:
SUB AX,AX MOV DX,AX ADD AX,BX ADD AX,CX ADC DX,0 ADD AX,SI ADC DX,0
23. 写出宏指令SUMMING,实现将字节缓冲区array中的内容求校验和(保留低8位),
并保存在VALUE中。
解:设array前两个字节保存缓冲区字节数,在宏指令SUMMING,将array和VALUE作为形式参数。
SUMMING MACRO array,VALUE L1:
LEA
SI,array
MOV CX,[SI] ADD XOR ADD INC LOOP
SI,2 AL,AL AL,[SI] SI L1
MOV VALUE,AL ENDM
- 22 -
微机原理与接口技术
第4章 汇编语言程序设计
1. 已知在BUF的起始处保存有N个字符的ASCII码,编写汇编语言程序实现,将这组字
符串传送到缓冲区BUFR中,并且使字符串的顺序与原来的顺序相反。 解:BUF
BUFR
MOV CX, N LEA SI, BUF LEA DI, BUFR ADD DI,CX DEC DI L1:
MOV AL,[SI] MOV [DI],AL INC SI DEC DI LOOP L1
2. 利用移位、传送和相加指令实现AX的内容扩大10倍。
解:将扩大后的结果放在DX:AX中,注意到10×AX=8×AX+2×AX。 XOR SHL RCL
DX,DX AX, 1 DX, 1
DB \DB 100 DUP(?)
MOV BX,AX MOV SHL RCL SHL
CX,DX AX, 1 DX, 1 AX, 1
- 23 -
微机原理与接口技术
RCL ADD ADC
DX, 1 AX, BX DX, CX
3. 在缓冲区VAR中连续存放着3个16位的无符号数,编写程序实现将其按递增关系排列;
如果VAR中保存的为有符号数,则再编写程序实现将其按递减关系排列。 解:VAR DW 1236,-432,3900
XOR SI,,SI MOV AX,VAR[SI] CMP AX, VAR[SI+2] JAE L1
XCHG AX, VAR[SI+2] L1:
CMP AX, VAR[SI+4] JAE L2
XCHG AX, VAR[SI+4] L2:
MOV VAR[SI], AX MOV AX,VAR[SI+2] CMP AX, VAR[SI+4] JAE L3
XCHG AX, VAR[SI+4] L3:
MOV VAR[SI+2], AX
4. 编写程序段实现将AL和BL中的每一位依次交叉,得到的16位字保存在DX中,例
如(AL)=01100101B,(BL)=11011010B,则得到的(DX)=10110110 10011001B。 解:利用移位指令完成。
XOR DX,DX MOV CX,8
- 24 -
微机原理与接口技术
L1:
SHR AL,1 RCR DX,1 SHR BL,1 RCR DX,1 LOOP L1
5. 在变量VAR1和VAR2中分别保存有两个字节型的正整数,编写完整的汇编语言程序实
现:
(1)当两数中有一个奇数时,将奇数存入VAR1,偶数存入VAR2;
(2)当两数均为奇数时,两个变量的内容不变; (3)当两数均为偶数时,两数缩小一倍后存入原处。
解:当VAR1为奇数时,不论VAR2的奇偶性,这两个单元的内容均不变;只有当VAR1为偶数时,如果VAR2为奇数,则VAR1与VAR2内容交换;如果VAR2为偶数,则两数缩小一倍后存入原处。 DATA SEGMENT VAR1 DB 28 VAR2 DB 36 DATA ENDS CODE SEGMENT
ASSUME CS:CODE, DS:DATA, ES:DATA
START:
MOV AX, DATA MOV DS,AX MOV ES, AX MOV AL,VAR1 MOV BL,VAR2 TEST AL,1 JZ
EVEN1
- 25 -
微机原理与接口技术
JMP OVER
EVEN1:
TEST BL,1
JZ EVEN2 MOV VAR1,BL
MOV JMP
VAR2,AL OVER
EVEN2:
SHR MOV SHR MOV
AL,1 VAR1,AL BL,1 VAR2,BL
OVER:
MOV AH,4CH MOV AL,0 INT ENDS END START
21H
CODE
6. 已知在字变量VAR1、VAR2和VAR3中保存有3个相同的代码,但有一个错码,编写
程序段找出这个错码,并将它送到AX,其地址送SI;如果3个代码都相同,则在AX中置-1标志。 解:在数据段中定义:
VAR1 DW 5A34H VAR2 DW 5A35H VAR3 DW 3A34H 在代码段中编写程序段:
MOV AX,-1 MOV BX,VAR1
- 26 -
微机原理与接口技术
CMP BX,VAR2 JZ L2 CMP BX,VAR3 JZ L1 MOV AX,BX LEA SI,VAR1 JMP OVER L1:
MOV AX,VAR2 LEA SI,VAR2 JMP OVER L2:
CMP BX,VAR3 JZ OVER MOV AX,VAR3 LEA SI,VAR3 OVER:
7. 分析下列程序段的功能:
MOV CL,04 SHL DX,CL MOV BL,AH SHL AX,CL SHR BL,CL OR DL,BL
解:程序段完成DX:AX组成的32位无符号数左移4位,低位补零(也即除以16)。 8. 下列程序段执行后,求BX寄存器的内容:
MOV CL,3 MOV BX,0B7H
- 27 -
微机原理与接口技术
ROL BX,1 ROR BX,CL
解:实际上完成BX内容循环右移2位,因此,BX寄存器的内容为C02DH。 9. 下列程序段执行后,求BX寄存器的内容:
MOV CL,5 MOV BX,7D5CH SHR BX,CL
解:完成BX内容逻辑右移5位,因此,BX寄存器的内容为03EAH。
10. 将BUFFERS中N个字按相反顺序传递到BUFFERT中。 解:
LEA SI,BUFFERS LEA DI,BUFFERT MOV CX,N ADD DI,N ADD DI,N SUB DI,2 L1:
MOV AX,[SI] MOV [DI],AX ADD SI,2 SUB DI,2 LOOP L1
11. 数组ARRAY中存放有一组字型数据,前两个字节存放数据长度(5的倍数)。为给这
个数组中的数据进行加密保护,每5个数据取出一个数据进行加密处理:奇数位进行取反,偶数位不变,例如对数据0110 1100 1011 0001B加密后变成1100 0110 0001 1011B,编写加密程序encrpytion 和解密程序 unencrpytion 。
解:约定从第一个数据开始,每5个数据为一组,每组中的第一个数据采取加密/解密处理。
- 28 -
微机原理与接口技术
由于加密算法采用的是取反操作,解密算法也采用取反操作,因此解密和解密算法是同一个程序。
ENCRPYTION PROC NEAR
LEA SI,ARRAY
XOR DX,DX MOV AX,[SI] MOV BX,5 DIV BX MOV CX, AX ADD SI, 2
L1:
MOV AX, [SI] XOR AX,0AAAAH MOV [SI], AX ADD SI,10 LOOP L1 RET
ENCRPYTION ENDP
13. 设BUF中存放有N个无符号数(或有符号数),编程实现求它们的最小值(存入AX)
和最大值(存入DX)。
解:BUF存放有N个无符号数的程序如下: MOV CX,N LEA SI,BUF MOV AX,[SI] MOV DX,AX ADD SI,2 L1:
- 29 -
微机原理与接口技术
CMP AX,[SI] JBE NOCHG1 XCHG AX,[SI] NOCHG1:
CMP DX,[SI] JAE NOCHG2 XCHG DX,[SI] NOCHG2:
ADD SI,2 LOOP L1
如果BUF中存放的是有符号数,则只需要将程序中的两行内容修改:
JBE NOCHG1 JAE NOCHG2
14. 设BUFFER中存放有N个无符号(第1个字节存放缓冲区的长度),编程实现将其中的
0元素抹去,并更新其长度。
解:设BUFFER中存放的是字节型数据。采用双指针方法:SI为读指针,DI为写指针,从低地址开始,内存中读出一个字节,如果不为0,则写入内存;如果为0,则不进行写操作。
LEA SI, BUFFER XOR CX,CX MOV CL, [SI] INC SI MOV DI, SI XOR BH,BH XOR AL,AL L1:
CMP [SI],AL
改成:JLE NOCHG1 改成:JGE NOCHG2
- 30 -
微机原理与接口技术
JZ L2 MOV BL,[SI] MOV [DI],BL INC DI INC BH L2:
INC SI LOOP L1
MOV BUFFER,BH
16. 编写一个子程序实现统计AL中1的个数,然后检测出字节型缓冲区BUF中0和1个
数相等的元素个数。
解:统计AL中1的个数,只需将AL右移,移出的一位内容进行累加,子程序为: COUNTBYTE PROC NEAR PUSH AX PUSH CX MOV CX,8 XOR BL,BL
COU1:
SHR AL,1 ADC BL,0 LOOP COU1 POP CX POP AX RET COUNTBYTE ENDP
在此基础上,可以检测出字节型缓冲区BUF中0和1个数相等的元素个数,即一个字
节中有4个1。设BUF中有N个字节型数据,结果保持在BH中。
- 31 -
微机原理与接口技术
MOV CX,N LEA SI, BUF XOR BH,BH L1: MOV AL,[SI]
CALL COUNTBYTE CMP BL,4 JNZ L2 INC BH L2: INC SI
LOOP L1
19. 在缓冲区BUFFER中,第1个字节存放数组的长度(<256),从第2个字节开始存放字
符的ASCII码,编写子程序完成在最高位给字符加上偶校验。 解:STACK SEGMENT STACK 'STACK' DW 100H DUP(?) TOP LABEL BYTE
STACK ENDS
DATA SEGMENT BUFFER DB 3 DB 'ABC'
DATA ENDS CODE SEGMENT
ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK
START:
MOV AX,STACK MOV SS,AX LEA SP,TOP
;首字节为字符串长度 ;字符串
- 32 -
微机原理与接口技术
MOV AX,DATA MOV DS,AX MOV ES,AX LEA DI,BUFFER XOR CX,CX MOV CL,[DI] INC DI
CALL SETEVEN MOV AH,4CH MOV AL,0 INT 21H SETEVEN PROC NEAR PUSH AX PUSH BX PUSH CX PUSH DI SETEVEN1:
MOV AL,[DI] CALL COUNTBYTE AND BL,01H JZ SETEVEN2 OR AL,80H MOV [DI],AL SETEVEN2: INC DI
LOOP SETEVEN1 POP DI POP CX
;加偶校验子程序
;返回DOS
- 33 -
微机原理与接口技术
POP BX POP AX RET SETEVEN ENDP COUNTBYTE
PROC NEAR
PUSH AX PUSH CX MOV CX,8 XOR BL,BL
COU1:
SHR AL,1 ADC BL,0 LOOP COU1 POP CX POP AX RET COUNTBYTE ENDP
CODE ENDS END START
20. 编写程序完成求多位数(N个字)的绝对值。
21. 已知斐波那契数列的定义为:F1?1,F2?1,Fi?Fi?1?Fi?2数列前n项的子程序。
解:设奖斐波那契数列存放在字变量RESULT中。在数据段中定义 RESULT DW 100H DUP(?)
在代码段中编写子程序 FIBONACCI
PROC NEAR
XOR DI,DI
- 34 -
(i?3),编写求该
微机原理与接口技术
MOV RESULT[DI],1 ;前两个数为1
MOV RESULT[DI+2],1
ADD DI,4 MOV CX,N
L1:
MOV AX, RESULT[DI-4] ADD AX, RESULT[DI-2] MOV RESULT[DI],AX ADD DI,2 LOOP L1 RET FIBONACCI ENDP
22. 编写程序实现循环显示10条信息,保存每条信息的变量分别为INFOM1~INFORM10。 解:在数据段中定义变量:
TABLE DW INFORM1, INFORM2, INFORM3, INFORM4, INFORM5 DW INFORM6, INFORM7, INFORM8, INFORM9, INFORM10 在代码段中编写程序段:
MOV XOR MOV MOV INT ADD CALL LOOP
CX,10 SI,SI
DX,TABLE[SI] AH,9 21H SI,2 WAIT L1
L1:
这里,WAIT为延时子程序,用于在显示信息之间的停顿。
- 35 -
微机原理与接口技术
23. 编写程序实现将包含20个数据的数组ARRAY分成两个数组:正数数组ARRAYP和负数数组ARRAYN,并分别将这两个数组中数据的个数显示出来。
解:先编写一个子程序DISPALD,完成以3位十进制数形式显示出AL的内容。
DISPALD PROC NEAR
PUSH AX PUSH CX PUSH DX XOR AH,AH MOV CL,100 DIV CL PUSH AX MOV DL,30H ADD DL,AL MOV AH,2 INT 21H POP AX MOV AL,AH XOR AH,AH MOV CL,10 DIV CL PUSH AX MOV DL,30H ADD DL,AL MOV AH,2 INT 21H POP AX MOV DL,30H ADD DL,AH
36 -
-微机原理与接口技术
MOV AH,2 INT 21H POP DX POP CX POP AX RET
DISPALD ENDP
在此基础上,根据题目要求,需要用到3个指针:SI指向源数组ARRAY,DI指向正数数组ARRAYP,BX指向负数数组ARRAYN。
MOV XOR LEA LEA LEA MOV AND JS MOV INC INC JMP MOV INC INC INC LOOP MOV
CX,20 DX,DX SI,ARRAY DI,ARRAYP BX,ARRAYN AL,[SI] AL,AL L2 [DI],AL DI DL L3 [BX],AL BX DH SI L1 AL,DL
L1:
L2:
L3:
- 37 -
微机原理与接口技术
CALL MOV CALL
DISPALD AL,DH DISPALD
24. 编写程序实现求缓冲区BUFFER的100个字中的最小偶数(存入AX)。 解:设BUFFER中存放的是有符号数。 L1: L2:
MOV CX,100 LEA SI,BUFFER MOV AX, 7FFFH AND WORD PTR [SI],1 JNZ L2 CMP [SI],AX JGE L2 MOV AX,[SI] ADD SI,2 LOOP L1
225. 编写程序实现求级数1解:BL用于存放项数。
?22???n2??的前n项和刚大于2000的项数n。
STACK SEGMENT STACK 'STACK' DW 100H DUP(?) TOP
LABEL WORD
STACK ENDS DATA SEGMENT DB 100H DUP(?) DATA ENDS CODE SEGMENT
ASSUME CS:CODE, DS:DATA, ES:DATA, SS:STACK START:
MOV AX,DATA
- 38 -
微机原理与接口技术
MOV DS,AX MOV ES,AX MOV AX,STACK MOV SS,AX LEA SP,TOP MOV BL,1 MOV CX,0 COUNT:
MOV AL, BL MUL BL ADD CX,AX CMP CX,2000 JA EXIT INC BL JMP COUNT
EXIT:
26. 定义一条宏指令,实现将指定数据段的段地址传送到段寄存器ES或DS的功能。 解:
27. 定义一条宏指令,实现从键盘中输入一个字符串(利用INT 21H的09号功能)。 28. 定义一条宏指令,实现在屏幕上输出回车、换行。 29. 利用其它指令完成与下列指令一样的功能:
(1)REP MOVSB; (3)REP STOSB;
解:设DF=0 (1)
L1: MOV AL,[SI]
MOV ES:[DI],AL INC
SI
(2)REP LODSB; (4)REP SCASB。
- 39 -
正在阅读:
微机原理习题答案1234章06-09
重庆市教育委员会文件 - 图文04-12
2015春西交《政治经济学》在线作业答案01-16
--,初中英语(在线测试)02-07
初中社会实践报告五篇范文08-22
赏秋作文400字06-29
一封表白情书02-19
义马市狂口学校严禁教师有偿补课开展情况汇报.doc07-23
产品全生命周期管理流程03-23
县移民局上半年度移民培训工作总结报告08-04
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 微机
- 习题
- 原理
- 答案
- 1234
- 银行贷后管理岗工作总结
- 智能家居系统 - 图文
- 冀教版小学语文五年级下册 第1单元单元测试卷B卷
- 商业网点规划说明书
- 浙江省温州中学2012-2013学年高一下学期期末物理试题 - Word版含
- 工商银行校招考试笔试经验五:工行知识
- 2009年高考汉语文模拟试题(一)
- 初中数学合作学习初探
- 深信服 技术服务面试题及答案
- 多媒体学习心得体会
- 石化钢结构安装方案
- 八寨沟现场教学的方案及讲解
- 计算机操作系统 实验一:进程调度实验报告书
- 教师如何提高自身素质
- 常见的酸和碱教案1--1
- 第一章 重难点一 常见有机化合物的结构
- 互维陈超经验正确认识SEO比SEO技术更重要
- 发挥高校后勤育人功能,建设大学“第三课堂”
- Linux学习练习命令
- 协议书的写法-范文word版(7页)