微机原理和接口技术习题答案解析3

上传人:沈*** 文档编号:67319191 上传时间:2022-03-30 格式:DOC 页数:24 大小:281.50KB
收藏 版权申诉 举报 下载
微机原理和接口技术习题答案解析3_第1页
第1页 / 共24页
微机原理和接口技术习题答案解析3_第2页
第2页 / 共24页
微机原理和接口技术习题答案解析3_第3页
第3页 / 共24页
资源描述:

《微机原理和接口技术习题答案解析3》由会员分享,可在线阅读,更多相关《微机原理和接口技术习题答案解析3(24页珍藏版)》请在装配图网上搜索。

1、完美格式整理版第3章8086CPU指令系统1.写出完成下列要求的变量定义语句:(1)在变量 varl中保存6个字变量:4512H, 4512,1, 100/3 , 10H, 65530;(2)在变量var2中保存字符串:BYTE , word,WORD;(3)在缓冲区buf1中留出100个字节的存储空间;(4)在缓冲区buf2中,保存5个字节的55H,再保存10个字节的240,并将这一过程学习好帮手(或者 pointer DW OFFSET var1, OFFSET buf1 )var1DB12var2DBvar3DWvar4DW var2var5DDvar2设变量var1AssembleAB

2、 ,cd , E(5)在变量var3中保存缓冲区buf1的长度;(6)在变量pointer中保存变量var1和缓冲区buf1var1DW4512H,4512,-1,100/3,10H,65530var2DBBYTE , word , WORDbuf1DB100 DUP (?)buf2DB7 DUP ( 5 DUP (55H) ,10 DUPvar3DBLENGTH buf1重复7次;的偏移地址。解:(240)poi nter DW var1,buf12.的逻辑地址为0100: 0000,画出下列语句定义的变量的存储分配图:,12, 20/6 , 4 DUP (0, 55H)解:aiaoiaaa

3、oKOCH03Ho5hHE亟55H35h35h55Hvarl41H73H73H65H62H6CH殆H42H41H64H诙45HDDHOOOBH0D13Hvsr2vsr30019H001BMvir4var53. 指令正误判断,对正确指令写出源和目的操作数的寻址方式,对错误指令指出原因(设VAR1, VAR2为字变量 丄1为标号):解:(1)MOV SI,100正确。源:立即数寻址,目的:寄存器寻址(2)MOV BX,VAR1SI正确。源:寄存器相对寻址,目的:寄存器寻址(3)MOV AX,BX正确。源:寄存器间接寻址,目的:寄存器寻址(4)MOV AL,DX错误。寄存器间接寻址时, DX, AX

4、, CX不能作地址寄存器(5)MOV BP,AL错误。操作数类型不一致(6) MOV VAR1,VAR2错误。两存储单兀之间不能用MOV指令传送数据(1) MOV SI, 100(2)MOV BX VAR1SI(3) MOV AX, BX(4)MOV AL, DX(5) MOV BP, AL(6)MOV VAR1, VAR2(7) MOV CS, AX(8)MOV DS, 0100H(9) MOV BXSI, 1(10)MOV AX, VAR1+VAR2(11) ADD AX, LENGTH VAR1(12)OR BL, TYPE VAR2(13) SUB DI, 78H(14)MOVS VA

5、R1, VAR2(15) PUSH 100H(16)POP CS(17) XCHG AX, ES(18)MOV DS, CS(19) JMP L1+5(20)DIV AX, 10(21) SHL BL, 2(22)MOV AL, 15+23(23) MUL CX(24)XCHG CL, SI(25) ADC CS:0100, AH(26)SBB VARJ 5,154(7) MOV CS,AX错误。CS不能为目的操作数(8) MOV DS,0100H错误。目的操作数为段寄存器时,源操作数不能为立即数错误。指令类型不定。(10) MOV AX,VAR1+VAR2 错误。MOV指令中不能完成加法运算

6、(11) ADD AX,LENGTH VAR1正确。源:立即数寻址。目的:寄存器寻址(12) OR BL,TYPE VAR2正确。源:立即数寻址。目的:寄存器寻址(13) SUB DI,78H错误。指令类型不定(14) MOVS VAR1,VAR2正确。目的、源均为隐含寻址。操作数仅指出操作数类型(16) POPCS错误。目的操作数不能为 CS(17) XCHG AX ES(18) MOV DS CS(19) JMP L1+5错误。XCHG旨令的操作数不能是段寄存器错误。MOV旨令不能从段寄存器到段寄存器正确。段内直接转移(20) DIVAX, 10错误。指令格式错误。(21) SHLBL,

7、2错误。移位指令的移位数为1或者CL(22) MOVAL, 15+23 正确。源:立即数寻址,目的:寄存器。编译时就处理为38(23) MULCX正确。源:寄存器寻址,目的:寄存器寻址(24) XCHG CL, SI正确。源:寄存器间接寻址,目的:寄存器寻址(15) PUSH 100H错误。将常数压入堆栈,要通过寄存器来实现(25)(26)SBBVAR1-5,154正确。源:立即数寻址,目的:直接寻址。ADC CS:0100,AH正确。源:寄存器寻址,目的:直接寻址(数据在代码段中)4. 说明下列指令对的区别:(1)MOV AXVAR1(2)MOV AXVAR2(3)MOV ALLENGTH(

8、4)MOV ALES: DI(5)SHR AL,1(6)SHR AL,1(7)ROL BX,11)MOV AX,VAR1解:(MOV AX ,VAR1MOV AX, OFFSET VAR1LEA AX , VAR2与 MOV AL, SIZE VAR1CMP AL, SISAR AL,ROR AL,RCL BX,OFFSET VAR1与 CMPSB把变量VAR1对应地址单元中的一个字送入AX把VAR1的有效地址的偏移地址送入AX(2) MOV AX VAR2 把变量 VAR2对应地址单元中的一个字送入AXLEA AX ,VAR2把VAR2的有效地址的偏移地址送入 AX(3)MOV AL LEN

9、GTH VAR1 把变量VAR1的长度送入 ALMOV AL SIZE VAR1把变量VAR1的大小送入AL(4)MOV AL,ES: DICMP AL,SI把以ES为段地址,DI为偏移地址的一个字节送入AL,并与以SI内容为偏移地址的一个字节作比较,改变标志寄 存器内容。(相当于作ES:(。1)与(DS: ( SI)内容比较)CMPSB对字符串中的一字节比较。寻址方式隐含。源串的地址由DS:SI指定,目的串的地址由ES:DI指定。(相当于作DS: ( SI)与ES:( DI)内容比较)(5) SHR AL,1AL逻辑右移1位,最高位移入 0,最低位移入CF。SAR AL,1 AL算术右移1位

10、,以最高位内容移入,最低位移入CF,其余各位右移一位。(6) SHR AL,1 AL逻辑右移1位,最高位移入 0,最低位移入 CF。ROR AL,1AL的各位构成环形移位,右移一位,最低位内容同时移入到CF和最高位。(7) ROL BX 1 BX各位构成环形移位,左移一位,最高位内容同时移入到CF和最低位。RCL BX 1 BX和CF构成环形移位,左移一位,CF内容移入到最低位,最高位移入CF。5. 写出下列转移指令的寻址方式(设L1为标号,VAR1为字型变量,DVAR1为双字型变量)(1) JMP L1(2)(3) JNZ L1(4)(5) JG L1(6)(7) JMP FAR PTR L

11、1(8)解:(1) JMP L1段内直接寻址(3) JNZL1段内直接寻址(5) JG L1段内直接寻址(7) JMP FAR PTR L1段间直接寻址JMP NEAR L1JMP BXJMP VAR1SIJMP DVAR1(2)JMP NEAR PTR L1段内直接寻址(4)JMP BX 段内间接寻址(6)JMP VAR1SI段内间接寻址(8)JMP DVAR1段间间接寻址6. 设(DS = 2000H, (BX) = 0100H, ( SI) = 0002H, (20100) = 3412H, (20102) = 7856H,(21200 )= 4C2AH ( 21202)= 65B7H,

12、求下列指令执行后 AX寄存器的内容:(1) MOV AX 1200H;( 2) MOV AX BX(3) MOV AX, 1200H;(4) MOV AX, BX;( 5) MOV AX,1100BX; (6) MOV AX, BXSI;(7) MOV AX,1100BXSI解:(1) 1200H(2) 0100H(3) 4C2AH (4) 3412H(5) 4C2AH(6) 7856H(7) 65B7H7. 执行下列指令后,DX寄存器中的内容是多少?TABLE DW 25,36, 1, 16, 10000, 13PYL DW 7MOV DX BX解:DX = 10FFH由-16 ( FFF0

13、H)的高8.如果堆栈的起始地址为2200: 0000ADD BX, PYLMOV BX, OFFSET TABLE8位和10000 (2710H)的低8位构成栈底为 0100H, (SF) = 00A8H,求(1) 栈顶地址;(2) SS的内容;(3)再存入数据5678H, 3AF2H后,SP 的内容。解:栈顶地址 00A8H , SS = 2200H ,再存入2个字后,SP = 00A4H9. 设已用伪指令 EQU定义了 4个标识符:N1 EQU 2100N2 EQU 10N3 EQU 20000N4 EQU 25000下列指令是否正确?并说明原因。(1) ADD AL, N1 N2;(3)

14、 SUB BX, N4 N3;(5) ADD AL, N2;解:(1)错误。N1-N2=2090255(2) MOV AX N3+ N4;(4) SUB AH N4- N3- N1;(6) MOV AH N2*N2(2)正确(3)正确(4)错误。N4-N3-N1=2900255(5)正确(6)正确10. 按下列要求写出指令:(1)将AX寄存器的低4位清零,其余位不变;(2)将BX寄存器的低4位置1,其余位不变;(3)将AL寄存器的低4位保持不变,高4位取反;(4)(5)(6)将AL中保存的字母ASCII码变换成相应的大写字母的ASCII 码;(7)将AL中保存的字母ASCII码变换成相应的小写

15、字母的ASCII 码;(8)将AX中的各位取反;(9)将DX中的低7位取反,高9位不变;测试BX中的位1和位2,当这两位同时为 0时将AL置OFFH否则AL清零;测试BX中的位1和位2,当这两位有一位为 0时将AL置0FFH否则AL清零;MOV AL 0FFH(1) AND AX,0FFF0H(2)OR BX,000FH(3)XOR AL,0F0H(4)TESTBX, 06H(5)MOV AX BXJZZEROAND AX ,MOV AL,00HXORAX, 06HJMPOVERJZOVER(10)将CX中的低8位与高8位互换。解:06HZERO MOV AL 0FFHOVEROVER(6)

16、AND AL,5FH或者:CMP AL61HJLOVER(无需变换或不:是字母)CMP AL7AHJGOVER(不是字母)AND AL,5FH或 SUBAL,20HOVER(7) OR AL, 20H或者:CMP AL41HJLOVER(不是字母)CMP AL5AHJGOVER(无需变换或不是:字母)OR AL,20H或 ADDAL,20HOVER(8) XOR AX, OFFFFH或者 NOT AX(9) XOR DX, 007FH(10) XCHG CH CL11. 写出完成下述功能的程序段:(1) 传送40H到AL寄存器;(2) 将AL的内容乘以2 ;(3) 传送16H到AH寄存器;(4

17、) AL的内容加上AH的内容。计算最后结果(AL)=?解:(1) MOV AL,40H(2) SHL AL,1(3) MOV AH,16H(4) ADD AL, AHAL=96H12. 写出完成下述功能的程序段:(1) 从缓冲区BUF的0004偏移地址处传送一个字到AX寄存器;(2) 将AX寄存器的内容右移 2位;(3) 将AX内容与BUF的0006偏移地址处的一个字相乘;(4) 相乘结果存入 BUF的0020H偏移地址处(低位在前)。解:(1) LEA SI, BUFMOV AX, SI+4(2) SHRAX,1SHRAX,1(3) MUL WORD PTR 6SI(4) MOV 20HSI

18、,AXMOV 22HSI,DX13. 设(BX)= 11001011B,变量VAR的内容为00110010B,求下列指令单独执行后 BX的内容:(2) AND BX VAR(4) XOR BX 11110000B;(6) TEST BX, 1(1) XOR BX VAR(3) OR BX VAR(5) AND BX 00001111B;解:(1)00F9H(2) 0002H(3) 00FBH(4) 003BH(5) 000BH(6) OOCBH=1,求下列指令单独执行后DX的内容:(3) SHL DX, CL;(6) ROL DL, CL;(9) RCR DL, 114. 设(DX) = 10

19、111011B, (CL)= 3, (CF)(1) SHR DX1 ;(2)SAR DX CL;(4) SHL DX,1 ;( 5)ROR DX CL;(7) SAL DH,1 ;(8)RCL DX CL;解:DX= 0000 0000 1011 1011B CF=1CL=3(1)SHRDX 1DX逻辑右移(2)SAR DXCLDX算术右移3(3)SHL DX,CLDX逻辑左移3(4)SHL DX,1DX逻辑左移1(5)ROR DXCLDX循环右移3(6)ROL DL,CLDL循环左移3(7)SAL DH,1DH算术左移1(8)RCL DXCLDX带进位循环左移10000 0000 0101

20、1101B=005DH0000 0000 0001 0111B=0017H0000 0101 1101 1000B=05D8H0000 0001 0111 0110B=0176H0110 0000 0001 0111B=6017H0000 0000 1101 1101B=00DDH0000 0000 1011 1011B=00BBH30000 0101 1101 1100B05DCH00DDH(9) RCR DL 1DL 带进位循环右移 10000 0000 1101 1101B=15. 选择题(各小题只有一个正确答案)(1) 执行下列三条指令后:MOV SP 1000HPUSH AXCALL

21、 BXa.(SP)= 1000H;b.(SP)= 0FFEHc.(SP)= 1004H;d.(SP)= 0FFCH(2) 要检查寄存器 AL中的内容是否与 AH相同,应使用的指令为:a. AND AL, AHb. OR AL, AHc. XOR AL, AH d. SBB AL, AH(3) 指令JMP NEAR PTR L1与CALL L1 ( L1为标号)的区别在于:a.寻址方式不同;b.是否保存IP的内容;c.目的地址不同;d.对标志位的影响不同。解: (1) D PUSHU AX则 AX入栈,SP=0FFEH CALL BX贝U IP 入栈,SP=0FFCH(2) C 异或,若相同,则

22、 AL=0, ZF= 1。(3) B16. 寄存器DX AX组成32位数,DX为高位,编写程序段实现:(1) DX AX右移3位,并将移出的低 3位保存在CL中;(2) DX AX左移3位,并将移出的高 3位保存在CL中;解:(1)移出的3位应该按时序移入 CL中。XOR CL,CLMOV BL,3L1: SHR DX, 1RCR AX, 1RCL CL, 1DEC BLJNZ L1(2)移出的3位应该按时序移入 CL中。XOR CL,CLMOV BL,3L1: SHL AX 1RCR DX 1RCR CL, 1DEC BLJNZ L117. 编写程序段实现将 BL中的每一位重复 4次,构成3

23、2位的双字 DX AX例如当BL=01011101B 时,则得到的(DX = OFOFH (AX)= 0FF0FH解:算术右移时,移入的值就是最高位本身,这样可以使位内容重复,利用这一点可以实现题目的要求。XOR DX,DXXOR AX,AXMOV CX,4L1: SHRBL,1RCR AX,1SARAX,1SAR AX,1SAR AX,1LOOP L1MOV CX,4L2:SHR BL,1RCR DX,1SARDX,1SARDX,1SARDX,1LOOPL218. 字变量VAR1中保存有小于38250的16位无符号数,编写程序段实现VAR仔150,并进行四舍五入操作,将商保存在字节变量VAR

24、2中。解:根据题意,38250150 = 255,因此商不会超过 255,可以用一个字节表示。完美格式整理版a4)的四舍五入操作可以通过判断除后余数实现:余数大于等于除数的一半, 则商加1;否则不用加1。但这种方法用汇编语言编程实现时比较复杂,这里介绍另外一种方法:设a4b的四舍五入后的结果为 c,用表示取整数操作,则这种方法是在除法操作之前, 在被除数上加上除数的一半, 这样除法操作后得到的值就是考 虑了四舍五入的商。VAR1DW 12345VAR2 DB ?DATAADB 150MOV AX,VAR1XOR BX,BXMOV BL,DATAASHR BX,1ADD AX,BXDIV DAT

25、AAMOV VAR2,AL19. 有一组无符号的16位数据保存在 BUFFER,前两个字节存放数据的个数,编程实现按下式进行滤波处理:1 ,y(k3x(k) x(kx(一2) k_2y(k)=x(k)k : 2解:滤波结果保存在 FILT中。BUFFER DW 0CHDW 33H, 18H, 1BH, 06H, 33H, 08HDW 3H, 6H, 0FH, 51H, 05H, 0CHFILT DW 100H DUP ( ?)LEA SI,BUFFER学习好帮手完美格式整理版LEA DI,FILTMOV CX,SIMOV DI,CXADD SI,2ADD DI,2XOR DX,DXMOV AX

26、,SIMOV DI,AXMOV BX,2SIMOV 2DI,BXADD SI,4ADD DI,4DEC CXDEC CXADD AX,BXADC DX,0L1:MOV BX,3ADD AX,SIADC DX,0PUSH DXPUSH AXDIV BXMOV DI,AXPOP AXPOP DXSUB AX, SI-4SUBB DX,0ADD DI,2ADD SI,2学习好帮手完美格式整理版LOOP L120. 在由字符串构成的缓冲区BUFFER,前2个字节存放字符个数,后续每个字节存放个字符的ASCII码。编写程序实现将字符串2004替换成2006。解:在数据段中定义:BUFFER DW 74D

27、B This year is 2004. In 2004, we have a plan for reducing annual expensive 10% DEST DB 2004在代码段中编写程序段:CLDLEA SI, BUFFERMOV CX,SIADD SI,2LEA DI,DESTL1:L2:PUSH SIPUSH DIPUSH CXMOV CX,4REPZ SCASBJNZL2MOV BYTE PTR SI-1, 6POPCXPOPDIPOPSIINCSIINCDILOOPL121. 定义有下列宏指令:学习好帮手WAGS MACRO S1,S2,S3SUB AX,AXMOV DX

28、,AXADD AX,S1ADD AX,S2ADC DX,0ADD AX,S3ADC DX,0ENDM当采用宏调用指令“ WAGS 60000 25000, 3000”时,执行后 DX= _AX =。解:宏指令 WAGS完成的功能为S1+S2+S3结果放在DX:AX中。所以,调用“WAGS60000,25000,3000 ”时,其结果为DX=0001H,AX=57C0H22. 对上题定义的宏指令,如果采用宏调用指令“WAGS BX,CX,S”时,写出宏展开形式。解:调用“ WAGS BX,CX,S”时,宏展开形式:SUB AX,AXMOV DX,AXADD AX,BXADD AX,CXADC DX,0ADD AX,SIADC DX,023. 写出宏指令SUMMIN,实现将字节缓冲区 array中的内容求校验和(保留低8位),并保存在VALUE中。解:设array前两个字节保存缓冲区字节数,在宏指令SUMMIN,将array和VALUE乍为形式参数。SUMMING MACRO array,VALUELEA SI,arrayMOV CX,SIXOR AL,ALL1:ADD AL,SIINCSILOOP L1MOVVALUE,ALENDM

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!