32位汇编语言习题及答案(全部)(钱晓捷版)ppt课件.ppt
《32位汇编语言习题及答案(全部)(钱晓捷版)ppt课件.ppt》由会员分享,可在线阅读,更多相关《32位汇编语言习题及答案(全部)(钱晓捷版)ppt课件.ppt(115页珍藏版)》请在三一办公上搜索。
1、32位汇编语言习题解答,课件制作: 钱晓捷,钱晓捷,32位汇编语言程序设计,机械工业出版社,第1章习题:汇编语言基础,1.1 简答题(1、3、6、7、8)1.2 判断题(1、6、7、8、9)1.3 填空题(3、4、5、7、10)1.9、1.13、1.15、1.16,3,1.1 简答题-1,(1)哪个处理器的指令系统成为Intel 80 x86系列处理器的基本指令集?8086(3)什么是通用寄存器?一般指处理器最常使用的整数寄存器,可用于保存整数数据、地址等(6)最高有效位MSB是指哪一位?数据的最高位,例如对8、16、32位数据,MSB依次指D7、D15和D31位,4,1.1 简答题-2,(7
2、)汇编语言中的标识符与高级语言的变量和常量名的组成原则有本质的区别吗?没有(8)汇编语言的标识符大小写不敏感意味着什么?表示字母大小写不同、但表示同一个符号,5,1.2 判断题,1)EAX也被称为累加器,因为它使用最频繁。对,EAX中的A来自英文累加器(Accumulator)6)处理器的传送指令MOV属于汇编语言的执行性语句对7)汇编语言的语句由明显的4部分组成,不需要分隔符区别。错,使用了分隔符才有了明显的4部分8)MASM汇编语言的注释用分号开始,不能用中文分号对,源程序中的分隔符以及各种标识符都是英文9)程序终止执行也就意味着汇编结束,所以两者含义相同。错,两者完全是两个概念,6,1.
3、3 填空题-1,(3)IA-32处理器有8个32位通用寄存器,其中EAX,_,_和EDX,可以分成16位和8位操作;还有另外4个是_,_,_,和_。EBX,ECX,ESI,EDI,EBP,ESP(4)寄存器EDX是_位的,其中低16位的名称是_,还可以分成两个8位的寄存器,其中D0D7和D8D15部分可以分别用名称_和_表示。32,DX,DL,DH(5)IA-32处理器有_个段寄存器,它们都是_位的。6,16,7,1.3 填空题-2,(7)逻辑地址由_和_两部分组成。代码段中下一条要执行的指令由CS和_寄存器指示,后者在实地址模型中起作用的仅有_寄存器部分。段基地址,偏移地址,EIP,IP(1
4、0)MASM要求汇编语言源程序文件的扩展名是_,汇编产生扩展名为OBJ的文件被称为_文件,编写32位Windows应用程序应选择_存储模型。ASM,目标模块,FLAT,8,习题1.9,IA-32处理器有哪三类基本段,各是什么用途?解答:代码段:存放程序的指令代码数据段:存放当前运行程序所用的数据堆栈段:主存中堆栈所在的区域,9,习题1.13,汇编语言语句有哪两种,每种语句由哪4个部分组成解答:汇编语句有两种执行性语句(处理器指令)说明性语句(伪指令)每个语句有4部分组成标号指令助记符操作数或参数注释,10,习题1.15,MASM汇编语言中,下面哪些是程序员可以使用的自定义标识符。FFH,DS,
5、Again,next,data,h_ascii,6364b,flat解答:FFH,Again,next,h_ascii其他符号错误的原因:DS是数据段寄存器名6364b是数字开头data是汇编语言使用预定义符号,表示数据段地址flat是表示平展存储模型的关键字,11,习题1.16,汇编语言程序的开发有哪4个步骤,分别利用什么程序完成、产生什么输出文件。解答:汇编语言程序的开发有4个步骤:编辑:用文本编辑器形成一个以ASM为扩展名的源程序文件。汇编:用汇编程序将ASM文件转换为OBJ模块文件。连接:用连接程序将一个或多个目标文件链接成一个EXE或COM可执行文件。调试:用调试程序排除错误,生成正
6、确的可执行文件。,第2章习题:数据表示和寻址,2.1 简答题(2、3、4、7、8)2.2 判断题(2、4、8、9、10)2.3 填空题(1、2、3、8、9)2.10、2.14、2.15、2.17,13,2.1 简答题-1,(2)字符“F”和数值46H作为MOV指令的源操作数有区别吗?没有,因为字符“F”的ASCII码就是数值46H(3)为什么可以把指令“MOV EAX, (3467H)*3”中的数值表达式看成是常量?汇编程序在汇编过程中对数值表达式计算,得到一个确定的数值,故称数值表达式为常量(4)汇编语言为什么规定十六进制数若以AF开头,需要在前面加个0?以便与标识符区别,因为标识符要求以字
7、母(或特殊符号)开头,14,2.1 简答题-2,(7)为什么将查找操作数的方法称为数据寻“址”方式?指令的操作数需要通过存储器地址或I/O地址,才能查找到数据本身,故称数据寻址方式(8)为什么变量VAR在指令“MOV EAX, VAR”中表达直接寻址?因为这里的变量名VAR实际上表达了从变量所存放的主存单元,即地址,15,2.2 判断题-1,(2)常用的BCD码为8421 BCD码,其中的8表示D3位的权重。对(4)用“BYTE”和“DWORD”定义变量,如果初值相同,则占用的存储空间也一样多。错。用BYTE只占一个存储单元,而DWORD要占4个存储单元(8)立即数寻址只会出现在源操作数中。对
8、,16,2.2 判断题-2,(9)存储器寻址方式的操作数当然在主存了。对(10)指令“MOV EAX, VAR+2”与“MOV EAX, VAR2”功能相同。对,仅是不同的形式罢了,17,2.3 填空题-1,(1)计算机中有一个“01100001”编码。如果把它认为是无符号数,它是十进制数_;如果认为它是BCD码,则表示真值_;又如果它是某个ASCII码,则代表字符_。97,61,小写字母a(2)C语言用“n”表示让光标回到下一行首位,在汇编语言中需要输出两个控制字符:一个是回车,其ASCII码是_,它将光标移动到当前所在行的首位;另一个是换行,其ASCII码是_,它将光标移到下一行。0DH(
9、13),0AH(10),18,2.3 填空题-2,(3)定义字节变量的伪指令助记符是_,获取变量名所具有的偏移地址的操作符是_。BYTE,OFFSET(8)指令“MOV EAX, OFFSET MSG”的目的操作数和源操作数分别采用_和_寻址方式。寄存器寻址,立即数寻址(9)已知ESI04000H,EBX20H,指令“MOV EAX, ESI+EBX*2+8”中访问的有效地址是_。04000H20H2804048H,19,习题2.10-1,按照如下要求定义变量或符号常量:(1) my1b为字符串变量:Personal Computermy1bbyte Personal Computer(2)
10、my2b为用十进制数表示的字节变量:20my2bbyte 20(3) my3b为用十六进制数表示的字节变量:20my3bbyte 14h(4) my4b为用二进制数表示的字节变量:20my4bbyte 00010100b,20,习题2.10-2,按照如下要求定义变量或符号常量:(5) my5w为20个未赋值的字变量my5wword 20 dup(?)(6) my6c为100的常量my6c= 100(7) my7c表示字符串:Personal Computermy7cequ ,21,习题2.14,按照如下输出格式,在屏幕上显示ASCII表编程在数据段直接构造这样的表格、填写相应ASCII代码值(
11、不是字符本身),然后使用字符串显示子程序DISPMSG实现显示,22,习题2.14解答1,.datatablebyte |0 1 2 3 4 5 6 7 8 9 A B C D E F, 13,10byte -+-, 13,10byte 20 |,20h,20h,21h,20h,22h,20h,23h,20h, 24h,20h,25h,20h,26h,20h,27h,20h,28h,20h,29h,20hbyte 2ah,20h,2bh,20h,2ch,20h,2dh,20h,2eh,20h, 2fh,20h,13,10byte 30 |,30h,20h,31h,20h,32h,20h,33h
12、,20h, 34h,20h,35h,20h,36h,20h,37h,20h,38h,20h,39h,20hbyte 3ah,20h,3bh,20h,3ch,20h,3dh,20h,3eh,20h, 3fh,20h,13,10byte 0,23,习题2.14解答2,ca=2cas=20hbyte ca,0 |,cas,20h,cas+1,20h,cas+2,20h, cas+3,20h,cas+4,20h,cas+5,20h,cas+6,20h,cas+7,20hbyte cas+8,20h,cas+9,20h,cas+0ah,20h,cas+0bh,20h, cas+0ch,20h,cas+0
13、dh,20h,cas+0eh,20h,cas+0fh,20h,13,10cas=cas+10hca=ca+1byte ca,0 |,cas,20h,cas+1,20h,cas+2,20h, cas+3,20h,cas+4,20h,cas+5,20h,cas+6,20h,cas+7,20hbyte cas+8,20h,cas+9,20h,cas+0ah,20h,cas+0bh,20h, cas+0ch,20h,cas+0dh,20h,cas+0eh,20h,cas+0fh,20h,13,10,24,习题2.15,数据段有如下定义:vardword 12345678h现以字节为单位按地址从低到高的
14、顺序,写出这个变量内容。var变量的内容:78H、56H、34H、12H并说明如下指令的执行结果:mov eax,var;EAX12345678Hmov bx,word ptr var;BX5678Hmov cx,word ptr var+2;CX1234Hmov dl,byte ptr var;DL78Hmov dh,byte ptr var+3;DH12H,25,习题2.17,说明源操作数的寻址方式,(1)mov edx,1234h立即数(2)mov edx,vard直接(3)mov edx,ebx寄存器(4)mov edx,ebx寄存器间接(5)mov edx,ebx+1234h寄存器相
15、对(6)mov edx,vardebx寄存器相对(7)mov edx,ebx+edi基址变址(8)mov edx,ebx+edi+1234h相对基址变址(9)mov edx,vardesi+edi相对基址变址(10)mov edx,ebp*4带比例寻址,第3章习题:通用数据处理指令,3.1 简答题(1、2、5、7、9)3.2 判断题(1、4、5、7、10)3.3 填空题(2、4、5、8、10)3.4、3.6、3.11、3.14、3.163.21、3.22,27,3.1 简答题-1,(1)如何修改“MOV ESI, WORD PTR 250”语句使其正确?删除“WORD PTR”即可(2)为什么
16、说“XCHG EDX,CX”是一条错误的指令?源、目标寄存器位数不同,不能用该指令进行数据交换(5)执行了一条加法指令后,发现ZF1,说明结果是什么?(5)表明运算结果为0,28,3.1 简答题-2,(7)大小写字母转换使用了什么规律?大小写字母转换利用它们的ASCII码相差20H(9)除法指令“DIV ESI”的被除数是什么?被除数64位,在EDX和EAX中,EDX保存高32位、EAX保存低32位,29,3.2 判断题-1,(1)指令“MOV EAX,0”使EAX结果为0,所以标志ZF1。错,MOV指令不影响标志(4)虽然ADD指令和SUB指令执行后会影响标志状态,但执行前的标志并不影响它们
17、的执行结果。对(5)80减90(8090)需要借位,所以执行结束后,进位标志CF1。对,减法时借位也用CF标志反映,30,3.2 判断题-2,(7)无符号数在前面加零扩展,数值不变;有符号数前面进行符号扩展,位数加长一位、数值增加一倍。错,符号扩展也不改变数值大小(10)SHL指令左移一位,就是乘10。错,左移一位,相当于乘2。这里的位是二进制比特位,31,3.3 填空题-1,(2)指令“POP EDX”的功能也可以用MOV和ADD指令实现,依次应该是_和_指令。MOV EDX,ESP,ADD ESP,4(4)进行8位二进制数加法:BAH6CH,8位结果是_,标志PF_。如果进行16位二进制数
18、加法:45BAH786CH,16位结果是_,标志PF_。26H,0,BE26H,0,32,3.3 填空题-2,(5)已知AX98H,执行“NEG AX”指令后,AX_,标志SF_。68H,0(8)指令“XOR EAX, EAX”和“SUB EAX, EAX”执行后,EAX_,CFOF_。而指令“MOV EAX, 0”执行后,EAX_,CF和OF没有变化。0,0,0(10)欲将EDX内的无符号数除以16,使用指令“SHR EDX, _”,其中后一个操作数是一个立即数。4,33,习题3.4,请给每种组合各举一个实例(1)mov reg, imm(2)mov mem, imm(3)mov reg,
19、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,34,习题3.6,使用MOV指令实现交换指令“XCHG EBX,EDI”功能。解答:mov eax,ebxmov ebx,edimov edi,eax,35,习题3.11-1,执行如下程序片断,说明每条指令的执行结果(1)mov eax,80h;EAX80Hadd eax,3;EAX83H,CF0,SF0add eax,80h;EAX103H,CF0,OF0adc eax,3;EAX106H,CF0,ZF0,
20、36,习题3.11-2,执行如下程序片断,说明每条指令的执行结果(2)mov eax,100;EAX100(64H)add ax,200;EAX300(12CH),CF0(3)mov eax,100;EAX100(64H)add al,200;EAX44(2CH),CF1(包含256的进位含义:25644300),37,习题3.11-3,执行如下程序片断,说明每条指令的执行结果(4)mov al,7fh;AL7FHsub al,8;AL77H,CF0,SF0sub al,80h;ALF7H,CF1,OF1sbb al,3;ALF3H,CF0,ZF0,38,习题3.14-1,请分别用一条汇编语言
21、指令完成如下功能:(1)把EBX寄存器和EDX寄存器的内容相加,结果存入EDX寄存器。add edx,ebx(2)用寄存器EBX和ESI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中。add al,ebx+esi,39,习题3.14-2,请分别用一条汇编语言指令完成如下功能:(3)用EBX和位移量0B2H的寄存器相对寻址方式把存储器中的一个双字和ECX寄存器的内容相加,并把结果送回存储器中。 add ebx+0b2h,ecx(4)将32位变量VARD与数3412H相加,并把结果送回该存储单元中。 add varw,3412h(5)把数0A0H与EAX寄存器的内容
22、相加,并把结果送回EAX中。 add eax,0a0h,40,习题3.16-1,执行如下程序片断,说明每条指令的执行结果(1)mov esi,10011100b;ESI 9CHand esi,80h;ESI 80Hor esi,7fh;ESI FFHxor 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,41,习题3.16-2,执行如下程序片断,说明每条指令的执行结果(3)mov eax,1011b;EAX
23、 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,42,习题3.21,如下程序片段实现EAX乘以某个数X的功能,请判断X?请使用一条乘法指令实现上述功能。mov ecx, eaxshl eax, 3lea eax, eax+eax*8sub eax, ecx解答:8*8+8-171imul eax, 71,43,习题3.22,请使用移位和加减法指令编写一个程序片段计算:EAX21,假设乘积不超过3
24、2位。提示:21242220。解答:mov ebx,eax;EBXEAX20shl ebx,2;EBXEAX22add eax,ebx;EAXEAX(2220)shl ebx,2;EBXEAX24add eax,ebx;EAXEAX(242220),第4章习题:程序结构,4.1 简答题(2、5、6、9、10)4.2 判断题(2、4、6、7、10)4.3 填空题(2、3、4、5、6)4.4、4.7、4.15、4.17、4.27、4.29,45,4.1 简答题-1,(2)数据的直接寻址和指令的直接寻址有什么区别?数据的直接寻址给出数据所在的存储器地址,指令的直接寻址给出指令所在的存储器地址。(5)
25、什么是奇偶校验?数据通信时,数据的某一位用做传输数据的奇偶校验位,数据中包括校验位在内的“1”的个数恒为奇数,就是奇校验;恒为偶数,就是偶校验(6)助记符JZ和JE为什么表达同一条指令?两个数相减,差值为0(JZ)与两个数相等(JE)是一个含义,46,4.1 简答题-2,(9)如果循环体的代码量远超过128个字节,还能用LOOP指令实现计数控制循环吗?不能,因为LOOP指令的目标地址采用相对短转移,只能在128127字节之间循环(10)什么是“先循环、后判断”循环结构?指先执行循环体,然后判断是否继续循环的结构,这种结构通常至少执行一次循环体,47,4.2 判断题,2)指令的相对寻址都是近转移
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 32 汇编语言 习题 答案 全部 钱晓捷版 ppt 课件
链接地址:https://www.31ppt.com/p-1946162.html