1、计算机组成原理与汇编语言程序设计课后习题及解答徐洁,俸远祯 电子工业出版社第 1 章 习题一1.什么是程序存储工作方式?答:计算机的工作方式存储程序工作方式。即事先编写程序,再由计算机把这些信息存储起来,然后连续地、快速地执行程序,从而完成各种运算过程。 2.采用数字化方法表示信息有哪些优点?用数字化方法表示信息的优点: (1)抗干扰能力强, 可靠性高。 (2)依靠多位数字的组合,在表示数值时可获得很宽的表示范围以及很高的精度。 (3)数字化的信息可以存储、信息传送也比较容易实现。 (4)可表示的信息类型与范围及其广泛,几乎没有限制。 (5)能用逻辑代数等数字逻辑技术进行信息处理,这就形成 了
2、计算机硬件设计的基础。 3.如果有 79 点阵显示出字符 A 的图像,请用 9 个七位二进制代码表示 A 的点阵信息。4.数字计算机的主要特点是什么?1. (1) 能在程序控制下自动连续地工作; (2| )运算速度快; (3) 运算精度高; (4) 具有很强的信息存储能力; (5) 通用性强,应用领域及其广泛。 5.衡量计算机性能的基本指标有哪些? 答:衡量计算机性能的基本指标:(1)基本字长参加一次运算的数的位数;(2)数据通路宽度数据总线一次能并行传送的位数;(3)运算速度可用CPU 的时钟频率与主频,每秒平均执行指令数,典型四则运算的时间来表示。(4)主存储器容量可用字节数或单元数(字数
3、)位数来表示。 (5)外存容量常用字节数表示。 (6)配备的外围设备及其性能。 (7)系统软件配置。7.系统软件一般包括哪些部分?列举你所熟悉的三种系统软件。系统软件一般包括操作系统,编译程序、解释程序、各种软件平台等。例如 WINDOWS98 操作系统,C 语言编译程序等,数据库管理系统。8.对源程序的处理有哪两种基本方式?对源程序的处理通常有两种处理方式:解释方式和编译方式。第 2 章 习题二1.将二进制数(101010.01)2 转换为十进制数及 BCD 码。解:(101010.01)2 = (42.25)10 = (01000010.00100101)BCD2.将八进制数(37.2)8
4、 转换为十进制数及 BCD 码.解:(37.2)8 = (31.25)10 =(00110001.00100101)BCD3.将十六进制数(AC.E)转换为十进制数及 BCD 码.解: (AC.E)16 =(172.875)10 = (000101110010.100001110101)BCD4.将十进制数(75.34)10 转换为 8 位二进制数及八进制数、十六进制数。解: (75.34)10 = (01001011.01010111)2 =(213.256)8 =(4B.57)165.将十进制数 13/128 转换为二进制数 .解: (13/128)10 =(1101/10000000)2
5、 =(0.0001101)26.分别写出下列各二进制数的原码、补码,字长(含一位数符)为 8 位。(1)0 (2)- 0 (3)0.1010 (4)- 0.1010 (5)1010 (6)-1010解: 原码 补码0 00000000 00000000-0 10000000 000000000.1010 0.1010000 0.1010000 - 0.1010 1.1010000 1.01100001010 00001010 00001010-1010 10001010 111101107.若 X 补=0.1010, 则 X 原、真值等于什么?解:X 补=0.1010 ,则 X 原=0.101
6、0,真值 X = 0.10108.若 X 补=1.1010, 则 X 原、真值等于什么?解:X 补=1.1010 ,则 X 原=1.0110,真值 X = - 0.01109.某定点小数字长 16 位,含 1 位符号,原码表示,分别写出下列典型值的二进制代码与十进制真值。(1)非 0 最小正数 (2) 最大正数 (3)绝对值最小负数 (4) 绝对值最大负数解: 二进制代码 十进制真值(1)非 0 最小正数 0.000000000000001 2-15(2)最大正数 0.111111111111111 1-2-15(3)绝对值最小负数 1.000000000000001 -2-15(4)绝对值最
7、大负数 1.111111111111111 -(1-2-15)10.某定点小数字长 16 位,含 1 位符号,补码表示,分别写出下列典型值的二进制代码与十进制真值。(1)非 0 最小正数 (2) 最大正数 (3)绝对值最小负数 (4) 绝对值最大负数解: 二进制代码 十进制真值(1)非 0 最小正数 0.000000000000001 2-15(2)最大正数 0.111111111111111 1-2-15(3)绝对值最小负数 1.111111111111111 -2-15(4)绝对值最大负数 1.000000000000000 -111.某浮点数字长 16 位,其中阶码 6 位,含 1 位符
8、号位,补码表示,以 2 为底;尾数 10 位(含 1 位数符),补码表示,规格化。分别写出下列各典型值的二进制代码与十进制真值。(1)非 0 最小正数 (2) 最大正数 (3)绝对值最小负数 (4) 绝对值最大负数解: 二进制代码 十进制真值(1)非 0 最小正数 100000, 0.100000000 (2)最大正数011111, 0.111111111 (3)绝对值最小负数100000, 1.100000000 (4)绝对值最大负数011111, 1.000000000 14.减少指令中一个地址码位数的方法是什么?答:减少指令中一个地址码位数的方法是采用寄存器寻址方式。15.某主存单元的地
9、址码与存储单元内容对应关系如下:地址码 存储内容1000H A307H1001H 0B3FH1002H 1200H1003H F03CH1004H D024H(1)若采用寄存器间接寻址读取操作数,指定寄存器 R0 的内容为 1002H,则操作数是多少?(2)若采用自增型寄存器间接寻址方式(R0)+,R0 的内容为 1000H,则操作数是多少?指令执行后 R0 的内容是什么?(3)若采用自减型寄存器间接寻址方式-(R1)+ 读取操作数, R1 的内容为 1003H,则操作数是多少?指令执行后 R1 的内容是什么?(4)若采用变址寻址方式 X(R2),指令中给出形式地址 d = 3H , 变址寄存
10、器 R2 的内容为 1000H,则操作数是多少?解:(1)操作数为 1200H。(2)操作数为 A307H,指令执行后 R0 的内容 1001H。(3)操作数为 F03CHH,指令执行后 R0 的内容 1002H。(4)操作数为 F03CHH。16.对 I/O 设备的编址方法有哪几种?请稍作解释。答:对 I/O 设备的编址方法有两种:外围设备单独编址和外围设备与主存统一编址。外围设备单独编址:为 I/O 接口中的有关寄存器分配 I/O 端口地址,一般由地址总线若干低位提供 I/O端口地址,从而选择某个寄存器进行读/写。外围设备与主存统一编址。将 I/O 接口中的有关寄存器与主存单元统一编址,一
11、般由地址码中高端(地址值大)的一段区域分配给 I/O 端口。17.I/O 的设置方法有哪几种?请稍作解释。答:I/O 指令的设置方法有三种:(1)设置专用的 I/O 指令:指令中的操作码明确规定某种输入/输出操作,CPU 寄存器号,I/O 端口地址。应用于外围设备单独编址方式。(2)用通用的数据传送指令实现 I/O 操作:应用于外围设备与主存单元统一编址方式。(3)通过 I/O 处理器或处理机控制 I/O 操作:应用于采用协处理器或多处理机的系统。第 3 章 习题三1.试说明串行进位和并行进位的不同之处。答:采用串行进位的加法器,是将 n 个加法器串接起来。其中的进位是逐级形成的,每一级的进位
12、直接依赖前一级的近位。由于串行进位的延时时间较长,所以速度很慢。采用并行进位的加法器中,各加法器的进位信号仅由进位产生函数 Gi 与进位传递函数 Pi 及最低位进位 C0 决定,而 Gi 和 Pi 之与本位的 Ai 和 Bi 有关,即 Gi 与 Pi 的形成是同时的,因此各级的进位输出 Ci也是同时形成的。并行进位有效地减少进位延时时间。3.用变形补码计算X 补+Y 补,并指出是否溢出,说明是正溢还是负溢。(1)X补=00 110011 Y补 = 00 1011010 0 1 1 0 0 1 1+) 0 0 1 0 1 1 0 10 1 1 0 0 0 0 0X补+Y 补 =01 100000
13、 , 符号位为 01,为正溢。(2)X补=00 010110 Y补 = 00 1001010 0 1 1 0 1 1 0+) 0 0 1 0 0 1 0 10 1 0 1 1 0 1 1X补+Y 补 =01 011011 , 符号位为 01,为正溢。(3)X补=11 110011 Y补 = 11 1011011 1 1 1 0 0 1 1+) 1 1 1 0 1 1 0 11 1 1 0 0 0 0 0X补+Y 补 =11 100000 , 符号位为 11,结果正确。(4)X补=11 001101 Y补 = 11 0100111 1 0 0 1 1 0 1+) 1 1 0 1 0 0 1 11
14、 0 1 0 0 0 0 0X补+Y 补 =10 100000 , 符号位为 10,为负溢。3.用变形补码计算X 补-Y补,并指出是否溢出,说明是正溢还是负溢。(1)X补=00 110011 Y补 = 00 101101解:-Y 补=11 0100110 0 1 1 0 0 1 1+) 1 1 0 1 0 0 1 10 0 0 0 0 1 1 0X补-Y 补=00 000110 , 符号位为 00,结果正确。(2)X补=00 110011 Y补 = 11 010011解:-Y 补=00 1011010 0 1 1 0 0 1 1+) 0 0 1 0 1 1 0 10 1 0 0 0 0 0 0
15、X补-Y 补=01 000000 , 符号位为 01,为正溢。(3)X补=00 100011 Y补 = 00 110100解:-Y 补=11 0011000 0 1 1 0 0 1 1+) 1 1 0 0 1 1 0 01 1 1 1 1 1 1 1X补-Y 补=11 111111 , 符号位为 11,结果正确。(4)X补=00 101010 Y补 = 11 110111解:-Y 补=00 0010010 0 1 0 1 0 1 0+) 0 0 0 0 1 0 0 10 0 1 1 0 0 1 1X补-Y 补=00 110011 , 符号位为 00,结果正确。6.用无符号数一位乘法计算 XY,
16、写出规范的运算过程。(1)X=1001 Y=1101(2)X=1101 Y=1111(3)X=1010 Y=10017.用无符号数不恢复余数法求 XY,写出运算过程,分别给出求得的商和余数。(1)X=00101001 Y=1011(2)X=00110110 Y=1111(3)X=01011010 Y=10018.简要解释下列名词术语:微命令,同步控制方式,指令周期,机器周期,时钟周期,时钟脉冲,指令流程,微指令,微程序,微周期,直接控制编码,分段直接译码法,分段间接译码法,增量方式,断定方式,垂直型微指令,水平型微指令。答:微命令构成控制信号序列的最小单位。例如打开或关闭某个控制门的电位信号,
17、某个寄存器的打入脉冲等。 同步控制方式同步控制方式是这样一种时序控制方式:各种操作都由统一的时序信号同步定时,它的主要特征是有固定的时钟周期划分。这意味着什么时间执行什么操作是事先安排好的。一个基本操作占用一个时钟周期(节拍) ,某个操作发生的时刻由相应的脉冲边沿定时。指令周期指令周期是从取指令、分析指令到执行完该指令所需的时间。不同的指令,其指令周期长短可以不同。机器周期在组合逻辑机控制器中,通常将指令周期划分为几个不同的阶段,每个阶段所需的时间,称为机器周期。例如,取指令周期、存储器读周期、存储器写周期等。时钟周期一个机器周期的操作一般需分为几步完成。因此,将一个机器周期划分为若干相等的时
18、间段,每个时间段内完成一步基本操作,这个时间段用一个电平信号宽度对应,称为节拍或时钟周期。指令流程指令流程体现了计算机工作原理中一个核心内容:CPU 究竟怎样执行指令流程?一般是给出一条特定的指令,以模型机 CPU 内部组成为背景,用寄存器传送级语句描述其读取与执行流程。微指令若干微命令的组合,以编码形式存放在控制存储器的一个单元中,控制实现一步操作。一条微指令的功能就是给出完成指令某步操作所需的微操作控制信号和后继微指令地址。微程序一条微指令包含的微命令控制实现一步(一个时钟周期)机器操作;若干条微指令组成一小段微程序,解释实现一条机器指令;控制存储器中的微程序能解释实现全部指令系统。微周期
19、通常指从控制存储器读取一条微命令并执行相应的微操作所需的时间。直接控制编码是指微指令的微命令字段中的每一位都代表一个微命令。设计微指令时,选用或不选用某个微命令,只要将表示该微命令的对应位设置成 1 或 0 就可以了。分段直接译码法将微指令的微命令字段分成若干小段,把相斥性微命令组合在同一段中,而把相容性微命令组合在不同的段中,每个字段独立编码,每种编码代表一个微命令,且各字段编码单独定义,与其它字段无关,这被称为分段直接译码法。分段间接译码法是在直接译码法的基础上,进一步缩短字长的一种编码方法。在这种编码法中,一个字段的含义不仅取决于本字段编码,还兼由其它字段来解释,以便使用较少的信息位表示
20、更多的微命令。增量方式与工作程序用程序计数器产生指令地址相似。在微程序控制器中,可设置一个微程序计数器 PC,在顺序执行指令时,后继微指令地址由现行微地址(即 PC的内容)加上一个增量(通常为1)来形成,遇到转移时,由微指令给出转移微地址,使微程序按新的顺序执行。断定方式指后继地址可由程序设计者指定,或者根据微指令所规定的测试结果直接决定后继微地址的全部或部分值。垂直型微指令垂直型微指令的特征是微指令较短,微指令的并行操作那里有限,一般一条微指令只能控制数据通路的一二种信息传送操作。水平型微指令它有如下特征:微指令较长,微指令中的微操作具有高度的并行性,微指令编码简单。优点是执行效率高,灵活性
21、好,微程序条数较少。9.试说明模型机中下列寄存器是作用:通用寄存器,暂存器,IR,PC,MAR,MDR答:通用寄存器是一组可编程访问,具有多种功能的寄存器。本身在逻辑上只具有接收信息、存储信息和发送信息的作用,但通过编程与运算部件的配合可以实现多种功能,如可为 ALU 提供操作数并存放运算结果,也可用作变址寄存器、地址指针和计数器等。暂存器用来暂存从主存储器读出的数据以及从 ALU 输出端输出的运算结果。IR用来存放当前正在执行的一条指令。PC提供指令的地址,即指示程序的进程。当现行指令执行完毕后,由 PC 提供后继指令的地址,并送往地址寄存器 MAR。MAR用于存放 CPU 访问主存或 I/
22、O 接口的地址。MDR用于存放 CPU 于主存或 I/O 接口之间传送的数据。10.模型机的脉冲型微命令有哪些?答:模型机中的脉冲型微命令有:CPR0,CPR1,CPR2,CPR3,CPIR,CPPC ,CPSP,CPMDR,CPMAR ,CPD,CPC,CPZ 。11.何谓组合逻辑控制器?何谓微程序控制器?试比较它们的优缺点。CPU 通过组合逻辑电路产生微命令,相应的控制器称为组合逻辑控制器。优点:速度快。缺点:设计较凌乱,不易修改扩充,应用于快速 CPU 中。CPU 采用微程序控制方式来产生微命令,相应的控制器称为微程序控制器。 优点:设计比较规整,易于修改扩充。缺点:速度较组合逻辑控制器
23、慢。12.拟出下述指令的读取与执行流程:(1)MOV R0,R2解:FT0 PCMARFT1 MMDRIR,PC+1PCST0 R2CET0 CR0(2)MOV R1,(PC)+解:FT0 PCMARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRCST2 PC+1ZST3 ZPCET0 CR0(3)MOV -(SP),-(R1)解:FT0 PCMARFT1 MMDRIR,PC+1PCST0 R1-1ZST1 ZMAR , R1ST2 MMDRCDT0 SP-1ZDT2 ZMAR ,SPET0 CMDRET1 MDRM(4)MOV (R0)+ , X(R3)解:FT0 PC
24、MARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRD , PC+1PCST2 D+R3ZST3 ZMARST4 MMDRCDT0 R0MARDT1 R0+1ZDT2 ZR0ET0 CMDRET1 MDRM(5)MOV (R0) , (PC)+解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRCST2 PC+1ZST3 ZPCDT0 R0MARET0 CMDRET1 MDRM(6)MOV DI ,(SP)+解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 SPMARST1 MMDRCST2 SP+1ZST3 ZSP
25、DT0 PCMARDT1 MMDRMAR ,PC+1PCET0 CMDRET1 MDRM13.拟出下述程序的读取与执行过程:(1)ADD R0,X(R1)解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRD , PC+1PCST2 D+R1ZST3 ZMARST4 MMDRCDTO R0DET0 C ADD DZET1 ZR0(2)SUB (R1)+,(PC)+解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRCST2 PC+1ZST3 ZPCDT0 R0MARDT1 MMDRDDT2 R0+1ZDT3 ZR0
26、ET0 C SUB DZET1 ZMDRET2 MDRM(3)AND (R3)+ , R0解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 R0CDT0 R3MARDT1 MMDRDDT2 R3+1ZDT3 ZR3ET0 C AND DZET1 ZMDRET2 MDRM(4)OR R0 , DI解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRMAR ,PC+1PCST2 MMDRC DT1 R0D ET0 C OR DZ ET1 ZR0(5)EOR -(R2) , R1解: FT0 PCMARFT1 MMDRIR,PC+1PCST0
27、R1CDT0 R2-1ZDT1 ZMAR , R2DT2 MMDRDET0 C EOR DZET1 ZMDRET2 MDRM(6)INC -(R2)解: FT0 PCMARFT1 MMDRIR,PC+1PCDT0 R2-1ZDT1 ZMAR , R2DT2 MMDRDET0 INC DZET1 ZMDRET2 MDRM(7)DEC (R1)解: FT0 PCMARFT1 MMDRIR,PC+1PCDT0 R1MARDT1 MMDRDET0 DEC DZET1 ZMDRET2 MDRM(8)COM (R0)+解: FT0 PCMARFT1 MMDRIR,PC+1PCDT0 R0MARDT1 MM
28、DRDDT2 R0+1ZDT3 ZR0ET0 COM DZET1 ZMDRET2 MDRM(9)NEG DI解: FT0 PCMARFT1 MMDRIR,PC+1PCDT0 PCMARDT1 MMDRMAR , PC+1PCDT2 MMDRDET0 NEG DZET1 ZMDRET2 MDRM(10)SAL R1解: FT0 PCMARFT1 MMDRIR,PC+1PCDT1 R1DET0 SAL DZET1 ZR1(11)SAR R2解: FT0 PCMARFT1 MMDRIR,PC+1PCDT1 R2DET0 SAR DZET1 ZR214.拟出下述程序的读取与执行过程:(1)JMP R1
29、解: FT0 PCMARFT1 MMDRIR,PC+1PCET0 R1PC(2)JMP (R0)解: FT0 PCMARFT1 MMDRIR,PC+1PCET0 R0MARET1 MMDRPC(3)JMP X(PC)解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 PCMARST1 MMDRD ST2 D+PCZST3 ZPC(4)RST (SP)+解: FT0 PCMARFT1 MMDRIR,PC+1PCET0 SPPCET1 MMDRPCET2 SP+1ZET3 ZPC(5)JSR R0解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 R0CET0 SP-1
30、ZET1 ZMAR , SPET2 PCMDRET3 MDRMET4 CPC(6)JSR (R3)解: FT0 PCMARFT1 MMDRIR,PC+1PCSTO R3MARST1 MMDRCET0 SP-1ZET1 ZMAR , SPET2 PCMDRET3 MDRMET4 CPC(7)JSR (R2)+解: FT0 PCMARFT1 MMDRIR,PC+1PCST0 R2MARST1 MMDRCST2 R2+1ZST3 ZR2ET0 SP-1ZET1 ZMAR , SPET2 PCMDRET3 MDRMET4 CPC第 4 章 习题四3. 在 8086/8088CPU 中,分别进行下列 8
31、 位二进制数的运算后,标志寄存器中 OF、ZF 、SF、CF 的值各是多少? (1)10101011+01010101 结果, OF=0 , ZF=1 , SF=0 , CF=1(2)11011010+11101101 (3)01010101 001111110 (4) 10110011 01100010 4. 在 002B0H 和 002B3H 字单元中,分别存放了 2 个 16 位字 2C53H 和 1F0EH, 试用图表示它们在存储器中的存储情况。 答案:5. 试说明段基址和段基值的不同之处。 答:一个段起始单元的地址称为段基址(20 位) ,其低 4 位必须位 0(可被 16 整除)
32、。 段基址的高 16 位称为段基值,它保存在段寄存器 CS、DS 、SS、ES 中。 6. 试说明 8086/8088 主存储器的逻辑地址由哪两部分组成。 答:逻辑地址:段基值:偏移量 7. 设某一存储单元的物理地址是 34567H,试完成下列不同的逻辑地址表示。 (1) 3456H:0007H (2)3400H:0567H 8. 假设某个程序装入主存后, (SS)= 0500H , (SP)= 64H,试计算该程序的堆栈栈底的物理地址。 解:SP 的内容为栈顶单元相对堆栈段段基址的字节距离(偏移量) 。当 SP 初始化时,其值为栈顶的长度(这时 SP 指向栈底+2 单元) 。所以堆栈栈底的物
33、理地址为: 0500H10H+64H-2 =05062H习题 9. 假设堆栈寄存器(SS)= 1E2CH,程序中设定堆栈的长度为 100 个字节。试计算该程序的堆栈栈底字单元的物理地址,堆栈指针 SP 的初始值(即堆栈中没有数据时)和 SP 初始值指向的物理地址。解: 100=64H 堆栈栈底字单元的物理地址: 1E2CH10H+64H-2=1E322H 堆栈指针 SP 的初始值: 64H SP 初始值指向的物理地址:1E2CH10H+64H=1E324H 习题 10. 设(SP)=40H,(BX)=1234H ,(DS)=5678H. 如现有两条压栈指令: PUSH BX PUSH DS 试
34、问两条指令执行后,图 4 46 中各单元的的数据是多少?(SP)等于多少? 答: (SP)=3CH 习题 11. 设(SP)=60H,则执行下述 3 条指令后,(水平)的值为多少? PUSH AX ; (SP)=5EH PUSH BX ; (SP)=5CH POP CX ; (SP)=5EH 解: (SP)=5EH 习题 12. 试分别说明下列各指令中源操作数和目的操作数使用的寻址方式,试说明如何确定有效地址EA. (1) ADD AX , 0A51H (2) MOV BL , DATA1 (3) MOV DS , AX (4) AND AL , VAR1+2 (5) TEST SI , CL
35、 (6) OR ARRYBX , - 1 (7) SUB DS:01FEH , DX (8) ADC BPDI , BH (9) AND CX , - 19BXSI (10) PUSH ES (11) CLC ; CF0 13. 试分别指出下列各指令语句的语法是否有错误,若有错,指明是什么错误。 (1) MOV AL , 0F5H ; (2) (2)ADD BXBP , BX ; (3) (3)CMP AL , 100H ; (4) (4)TEST BP , DL ; (5) (5)ADC 15H , CL ; ADC 是双操作数指令; 目的地址不能为立即数 (6) (6)SUB DI , D
36、A_WORD ; 源操作数和目的操作数不能同时为存储器操作数 (7) (7)OR CH , CL ; (8) (8)MOV AL , 1000H ; 源操作数和目的操作数类型属性不一致 (9) (9)SAR 10HDI , 2 ; 移位次数大于 1 时, 应由 CL 指定移位次数 (10) NOT AL , BL ; NOT 是单操作数指令 (11) (11)DEC CX , 1 ; DEC 是单操作数指令 (12) (12)LEA ES , TABBX ; LEA 指令的目的地址必须是通用寄存器 14. 执行下面 2 条指令后,标志寄存器中 CF,AF,ZF,SF 和 OF 分别是多少? M
37、OV AL , 91 ;91=01011011B ADD AL , 0BAH ; 0BAH=10111010B 15. 假设(DS) = 091DH , (SS) = 1E4AH , (AX) = 1234H , (BX) = 0024H , (CX) = 5678H , (BP) = 0024H , (SI) = 0012H , (DI) = 0032H , (09226H) = 00F6H , (09228H) = 1E40H , (1E4F6H) = 091DH . 试给出下列各指令或程序段执行的分别执行的结果. (1) (1)MOV CL , 20HBXSI 解 : 源操作数的物理地址
38、 : (DS)10H + 20H+(BX)+(SI) 将 09226H 字节单元的内容送 CL,结果(CL) = 00F6H (2) MOV BPDI , CX 解 : 目的操作数的物理地址 : (SS)10H + (BP)+(DI) 将 CX 寄存器的内容传送到 1E4F6H 字单元 , 结果 (1E4F6H) = (CX) = 5678H (3) (3)LEA BX , 20HBXSI MOV AX , 2BX 解 : 执行完第一句指令后 ,BX 的内容为: 第二句指令中,源操作数的物理地址为 EA = (DS)10H+2+(BX) 将 09228H 字单元的内容送 AX 寄存器 , 结果
39、 (AX) = 1E40H (4)LDS SI , BXDI MOV SI , BX 解 : 第一句指令中源操作数的逻辑地址为 DS:(BX)+(DI) 其偏移量为 (BX)+(DI) = 0024H+0032H = 0056H, 执行完第一句指令后, (SI) = 0056H 第二句指令中,源操作数的物理地址为 (DS)10H+(SI) = 091D0H+0056H = 09226H 将 BX 寄存器的内容送 09226 单元 , 结果 (09226H) = (BX) = 0024H (5)(5)XCHG CX , 32HBX XCHG 20HBXSI , AX 解 : 第一句指令中源操作数
40、的物理地址为 (DS) 10H+32H+(BX)= 09226H 09226H 字单元和 CX 寄存器的内容交换,结果 (CX) = 00F6H ,(09226H) = 5678H 第二句指令中目的操作数的物理地址为 (DS) 10H+20H+(BX)+(SI) = 09226H 09226H 字单元和寄存器 AX 的内容交换, 结果 (09226H) = 1234H , (AX) = 5678H 16. 假设(SS)=0915H , (DS) = 0930H , (SI) = 0A0H , (DI) = 1C0H , (BX) = 80H , (BP) = 470H . 现有一指令“MOV
41、AX , OPRD”, 若源操作数的物理地址为 095C0H , 试用 4 种不同寻址方式改写此指令,并要求至少使用上述条件一次. 解: 源操作数的物理地址与 DS 段基址的差为 095C0H 09300H = 2C0H MOV AX , 100HDI ; 源操作数的物理地址为: (DS)10H+100H+(DI) = 09300H + 100H + 1C0H =095C0H MOV AX , 220HSI ; 源操作数的物理地址为: (DS)10H+220H+(SI) = 09300H + 220H + 0A0H =095C0H MOV AX , 240HBX ; 源操作数的物理地址为: (
42、DS)10H+240H+(BX) = 09300H + 240H + 080H =095C0H MOV AX , 1A0HSIBX ;源操作数的物理地址为: (DS)10H+0A0H+(SI)+(BX) = 09300H + 1A0H + 0A0H +080H = 095C0H 18. 假设(AX)=0A5C6H , (CX) = 0F03H , 则下列 4 条指令执行后 , (AX) = 81C6H , CF= 1 . STC ; CF = 1 RCL AX , CL ; AX= 0010 1110 0011 0110 , CF = 1 AND AH , CH ; AH = 0000 111
43、0 , CF = 0 RCR AX , CL ; AX = 1000 0001 1100 0110, CF = 1 19. 假设(AX) = 0FC77H , (CX) = 504H , 则下列 4 条指令执行后 , (AX) = , CF = . CLC ; CF = 0 SAR AX , CL ; (AX) = 1111 1111 1100 0111 , CF = 0 XCHG CH , CL ; (CX) = 405H SHL AX , CL ; (AX) = 1111 1000 1110 0000 ,CF = 1 20. 假设(AX) = 1234H , (BX) = 0FFFFH ,
44、 则下述 3 条指令执行后 , (AX) = 1236H , (BX) = 0001H . INC AX ; (AX) = 1235H NEG BX ; (BX) = 0000 0000 0000 0001B = 0001H ADD AX , BX ; (AX) = 1236H 21. 假设(AX) = 0FFFFH , 则下述程序段执行后 , (AX) = 0001H . INC AX ; (AX) = 0000H NEG AX ; (AX) = 0000 0000 0000 0001B = 0000H DEC AX ; (AX) = 0FFFFH NEG AX ; (AX) = 0001H
45、 22. 假设(BX) = 12FFH , 则下述程序段执行后 , (BX) = 0012H , ZF = 0 , CF = 0 . MOV CL , 8 ;(CL)=8 ROL BX , CL ;(BX) = 1111 1111 0001 0010B = 0FF12H AND BX , 0FFH ; (BX) = 0012H CMP BX , 0FFH ; (BX) = 0012H CF=0 ,ZF=0 解: 第一句指令执行后 , (CL)=8 第二句指令执行后 , (BX) = 1111 1111 0001 0010B = 0FF12H 第三句指令执行后 , (BX) = 0012H 第四句指令执行后 , (BX) = 0012H CF=0 ,ZF=0 23. 假设(AX) = 0B55BH , (DX) = 0F0FH , 则下述程序段执行后 , (AX) = 0FBABH. AND AH , DL ; (AX) = 055BH XOR AL , DH ;(AX) = 0554H NEG AH ;(BX) = 1111 1011 0101 0100B = 0FD54H NOT AL ; (AX) = 11