第3章_通用数据处理指令习题答案_第1页
第3章_通用数据处理指令习题答案_第2页
第3章_通用数据处理指令习题答案_第3页
第3章_通用数据处理指令习题答案_第4页
第3章_通用数据处理指令习题答案_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第三章 通用数据处理指令3.1 简答题(1)如何修改“MOV ESI, WORD PTR 250”语句使其正确?删除“WORD PTR”即可(2)为什么说“XCHG EDX,CX”是一条错误的指令?源、目标寄存器位数不同,不能用该指令进行数据交换(3)说IA-32处理器的堆栈“向下生长”是什么意思?入栈时堆栈指针寄存器做减法操作,指向低地址;出栈时堆栈指针寄存器做加法操作,指向高地址(4)都是获取偏移地址,为什么指令“LEA EBX,ESI”正确,而指令“mov ebx,offset ESI”就错误?LEA指令时运行时计算地址,OFFSET是汇编时取地址。(5)执行了一条加法指令后,发现ZF1

2、,说明结果是什么?表明运算结果为0(6)INC、DEC、NEG和NOT都是单操作数指令,这个操作数应该是源操作数还是目的操作数?既是源操作数,也是目的操作数(7)大小写字母转换使用了什么规律?大小写字母转换利用它们的ASCII码相差20H(9)除法指令“DIV ESI”的被除数是什么?被除数64位,在EDX和EAX中,EDX保存高32位、EAX保存低32位(10)逻辑与运算为什么也称为逻辑乘?运算规则类似于2进制乘法。3.2 判断题(1)指令“MOV EAX,0”使EAX结果为0,所以标志ZF1。错,MOV指令不影响标志(2)空操作NOP指令其实根本没有指令。错,(3)堆栈的操作原则是“先进后

3、出”,所以堆栈段的数据除了PUSH和POP指令外,不允许其他方式读写。错(4)虽然ADD指令和SUB指令执行后会影响标志状态,但执行前的标志并不影响它们的执行结果。对(5)80减90(8090)需要借位,所以执行结束后,进位标志CF1。对,减法时借位也用CF标志反映(6)指令“INC ECX”和“ADD ECX,1”实现的功能完全一样,可以互相替换。错,INC 不影响CF位。(7)无符号数在前面加零扩展,数值不变;有符号数前面进行符号扩展,位数加长一位、数值增加一倍。错,符号扩展也不改变数值大小(8)CMP 指令是目的操作数减去源操作数,与SUB指令功能相同错(9)逻辑运算没有进位或溢出问题,

4、此时CF和OF没有作用,所以逻辑运算指令将CF和OF设置为0错(10)SHL指令左移一位,就是乘10。错,左移一位,相当于乘2。这里的位是二进制比特位3.3 填空题(1)指令“PUSH DS”执行后,ESP会 _. 减 2 (2)指令“POP EDX”的功能也可以用MOV和ADD指令实现,依次应该是_和_指令。MOV EDX,ESP,ADD ESP,4(3)例子3-3 的TAB定义如果是1234567890,则显示结果是 _78894111(4)进行8位二进制数加法:BAH6CH,8位结果是_,标志PF_。如果进行16位二进制数加法:45BAH786CH,16位结果是_,标志PF_。26H,0

5、,BE26H,0(5)已知AX98H,执行“NEG AX”指令后,AX_,标志SF_。68H,0(6)假设CL=98H,执行“MOVZX DX,CL”后,DX = _,这称为_。0098h,零位(7)假设CL=98H,执行“MOVSX DX,CL”后,DX = _,这称为_。ff98h,符号(8)指令“XOR EAX, EAX”和“SUB EAX, EAX”执行后,EAX_,CFOF_。而指令“MOV EAX, 0”执行后,EAX_,CF和OF没有变化。0,0,0(9)例子3-9 的程序执行结束后,变量qvar的内容是_(10)欲将EDX内的无符号数除以16,使用指令“SHR EDX, _”,

6、其中后一个操作数是一个立即数。4习题3.4请给每种组合各举一个实例(1)mov reg, imm(2)mov mem, imm(3)mov reg, reg(4)mov mem, reg(5)mov seg, reg(6)mov reg, mem(7)mov seg, mem(8)mov reg, seg(9)mov mem, seg习题3.5操作数的组合通常符合逻辑,但是不能任意,指出下列指令的错误原因(1) mov ecx,dl位数不同(2)mov eip,axeip为专用寄存器(3)mov es,1234h段寄存器不能直接用imm赋值(4)mov es,ds段寄存器间不能相互赋值(5)m

7、ov al,300h位数不同(6)mov esi,45h类型不明确(7)mov eax,ebx+edi无该种寻址方式(8) mov 20h,al立即数不能做操作数习题3.6使用MOV指令实现交换指令“XCHG EBX,EDI”功能。解答:mov eax,ebxmov ebx,edimov edi,eax习题3.7什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应指令是什么。主存储器中的以“先进后出”规则访问的内存区,入栈、出栈,push ,pop习题3.11执行如下程序片断,说明每条指令的执行结果(1)mov eax,80hadd eax,3add eax,80hadc eax,3(2

8、)mov eax,100add ax,200(3)mov eax,100add al,200(包含256的进位含义:25644300)(4)mov al,7fhsub al,8sub al,80hsbb al,3解答:(1)mov eax,80h;EAX80Hadd eax,3;EAX83H,CF0,SF0add eax,80h;EAX103H,CF0,OF0adc eax,3;EAX106H,CF0,ZF0(2)mov eax,100;EAX100(64H)add ax,200;EAX300(12CH),CF0(3)mov eax,100;EAX100(64H)add al,200;EAX4

9、4(2CH),CF1(包含256的进位含义:25644300)(4)mov al,7fh;AL7FHsub al,8;AL77H,CF0,SF0sub al,80h;ALF7H,CF1,OF1sbb al,3;ALF3H,CF0,ZF0习题3.12给出下列各条指令执行后al的值,以及CF、ZF、SF、OF和PF的状态。Moval,89hAddal,alAddal,9dhCmpal,0bchSubal,alDecalIncal解答:Moval,89h;89h,不影响标志位Addal,al;12h,cf=1,zf=0,sf=0,of=1,pf=1Addal,9dh;0afh,cf=0,zf=0,s

10、f=1,of=0,pf=1Cmpal,0bch;0afh,cf=1,zf=0,sf=1,of=0,pf=1Subal,al;0,cf=0,zf=1,sf=0,of=0,pf=1Decal;ffh,cf=0,zf=0,sf=1,of=0,pf=1Incal;0h,cf=0,zf=1,sf=0,of=0,pf=1习题3.13如下两段程序执行后,EDX.EAX寄存器对的值各是多少?(1)加法程序Movedx,11hMoveax,0b0000000hAddeax,040000000hAdcedx,0(2)减法程序Movedx,100hMoveax,64000000hSubeax,84000000hSb

11、bedx,0解答:(1)EDX=11EAX=0f0000000h(2)0ffh,0e00000000h习题3.14请分别用一条汇编语言指令完成如下功能:(1)把EBX寄存器和EDX寄存器的内容相加,结果存入EDX寄存器。(2)用寄存器EBX和ESI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中。(3)用EBX和位移量0B2H的寄存器相对寻址方式把存储器中的一个双字和ECX寄存器的内容相加,并把结果送回存储器中。(4)将32位变量VARD与数3412H相加,并把结果送回该存储单元中。(5)把数0A0H与EAX寄存器的内容相加,并把结果送回EAX中。解答:(1)把E

12、BX寄存器和EDX寄存器的内容相加,结果存入EDX寄存器。add edx,ebx(2)用寄存器EBX和ESI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中。add al,ebx+esi(3)用EBX和位移量0B2H的寄存器相对寻址方式把存储器中的一个双字和ECX寄存器的内容相加,并把结果送回存储器中。add bx+0b2h,cx(4)将32位变量VARD与数3412H相加,并把结果送回该存储单元中。add varw,3412h(5)把数0A0H与EAX寄存器的内容相加,并把结果送回EAX中。add eax,0a0h习题3.15有两个64位无符号整数分别存放在变量

13、buffer1和buffer2中,定义数据并编写代码完成edx.eax<- buufer1 - buffer2的功能。解答:.dataBuffer1 qword?Buffer2qword?.codeMoveax,dword ptr buffer1Movedx,dword ptr buffer2 + 4Addeax,dword ptr buffer2Adcedx,dword ptr buffer2 + 4习题3.16执行如下程序片断,说明每条指令的执行结果(1)mov esi,10011100b;ESI _Hand esi,80h;ESI _Hor esi,7fh;ESI _Hxor es

14、i,0feh;ESI _H(2)mov eax,1010b;EAX _B(可有前导0)shr eax,2;EAX _B,CF_shl eax,1;EAX _B,CF_and eax,3;EAX _B,CF_(3)mov eax,1011b;EAX _B(可有前导0)rol eax,2;EAX _B,CF_rcr eax,1;EAX _B,CF_or eax,3;EAX _B,CF_(4)xor eax,eax;EAX_,CF_,OF_;ZF_,SF_,PF_解答:(1)mov esi,10011100b;ESI 9CHand esi,80h;ESI 80Hor esi,7fh;ESI FFHx

15、or esi,0feh;ESI 01H(2)mov eax,1010b;EAX 1010B(可有前导0)shr eax,2;EAX 0010B,CF1shl eax,1;EAX 0100B,CF0and eax,3;EAX 0000B,CF0(3)mov eax,1011b;EAX 1011B(可有前导0)rol eax,2;EAX 101100B,CF0rcr eax,1;EAX 10110B,CF0or eax,3;EAX 10111B,CF0(4)xor eax,eax;EAX0,CF0,OF0;ZF1,SF0,PF1习题3.17给出下列各条指令执行后ax的结果,以及状态标志CF、OF、

16、SF、ZF、PF的状态。Movax,1470hAndax,axOrax,axXorax,axNotaxTestax,0f0f0h解答:Ax=1470h flags 不变Ax=1470hcf=of=0 sf=0 zf=0 pf=0Ax=1470h cf=of=0 sf=0 zf=0 pf=0Ax=0 cf=of=0 sf=0 zf=1 pf=1Ax=ffffh flags 不变Ax=ffffh cf=of=0 sf=1 zf=0 pf=1习题3.18举例说明逻辑运算指令怎样实现复位、置位和求反功能。解答:复位 使用逻辑与指令and ,例如将al寄存器 D0位复位,指令 and al,0feh置位

17、 使用逻辑或指令or ,例如将al寄存器 D0位置位,指令 or al,01求反 使用not指令,例如将ebx寄存器内容求反,指令not ebx习题3.19编程将一个压缩BCD码变量(如92h)转换为对应的ASCII码,然后调用dispc字程序(在输入输出字程序中)显示。解答:.dataBcd1byte92hMoval,bcd1Shral,4Oral,30hCalldispcMoval,bcd1Andal,0fhOral,30hCalldispc习题3.20有4个32位有符号数,分别保存在var1,var2,var3,var4变量中,阅读如下程序片段,得出运算公式,并说明运算结果存于何处。Mo

18、veax,var1Imulvar2Movebx,var3Movecx,ebxSarecx,32Addeax,ebxAdcedx,ecxSubeax,540Sbbedx,0Idivvar4解答:(var1*var2)+var3-540)/var4,结果存于edx,eax中习题3.21如下程序片段实现EAX乘以某个数X的功能,请判断X?请使用一条乘法指令实现上述功能。mov ecx, eaxshl eax, 3lea eax, eax+eax*8sub eax, ecx解答:8*8+8-171imul eax, 71习题3.22 请使用移位和加减法指令编写一个程序片段计算:EAX×21,

19、假设乘积不超过32位。提示:21242220。解答:mov ebx,eax;EBXEAX×20shl ebx,2;EBXEAX×22add eax,ebx;EAXEAX×(2220)shl ebx,2;EBXEAX×24add eax,ebx;EAXEAX×(242220)习题3.23阅读如下程序,为每条指令添加注释,指出其功能或作用,并说明这个程序运行后显示的结果。如果将程序中的寄存器间接寻址替换为寄存器相对寻址,如何修改程序?.data Num byte 6,7,7,8,3,0,0,0Tab byte 67783000.codeMovecx

20、,lengthof num;Movesi,offset num;Movedi,offset tab;Again:Moval,esi;Xchgal,edi;Movesi,al;CalldispcAddesi,1;Addedi,1;Loopagain解答:.data Num byte 6,7,7,8,3,0,0,0Tab byte 67783000.codeMovecx,lengthof num;ecx赋值为num数组长度Movesi,offset num;esi赋值为num偏移地址Movedi,offset tab;edi赋值为tab字符串偏移地址Again:Moval,esi;读取num元素到a1Xchgal,edi;互换al与tab元素Movesi,al;al存入num数组相应单元CalldispcAddesi,1;指向num下一元素Addedi,1;指向下一字符Loopagain结果:67783000修改程序:Movecx,lengthof numXoresi,es

温馨提示

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

评论

0/150

提交评论