收藏 分销(赏)

第2章_数据表示和寻址习题答案.doc

上传人:s4****5z 文档编号:8819927 上传时间:2025-03-03 格式:DOC 页数:16 大小:74.50KB 下载积分:10 金币
下载 相关 举报
第2章_数据表示和寻址习题答案.doc_第1页
第1页 / 共16页
第2章_数据表示和寻址习题答案.doc_第2页
第2页 / 共16页


点击查看更多>>
资源描述
第2章 数据表示和寻址 2.1 简答题 (2)字符“'F'”和数值46H作为MOV指令的源操作数有区别吗? 没有,因为字符“'F'”的ASCII码就是数值46H (3)为什么可以把指令“MOV EAX, (34+67H)*3”中的数值表达式看成是常量? 汇编程序在汇编过程中对数值表达式计算,得到一个确定的数值,故称数值表达式为常量 (4)汇编语言为什么规定十六进制数若以A~F开头,需要在前面加个0? 以便与标识符区别,因为标识符要求以字母(或特殊符号)开头 (7)为什么将查找操作数的方法称为数据寻“址”方式? 指令的操作数需要通过存储器地址或I/O地址,才能查找到数据本身,故称数据寻址方式 (8)为什么变量VAR在指令“MOV EAX, VAR”中表达直接寻址? 因为这里的变量名VAR实际上表达了从变量所存放的主存单元,即[地址] 2.2 判断题 (1)对一个正整数,它的原码、 反码和补码都一样,也都与无符号数的编码一样。 对 (2)常用的BCD码为8421 BCD码,其中的8表示D3位的权重。 对 (3)排序一般按照ascii码值大小,从小到大升序排列是,小写字母排在大写字母之前。 错 (4)用“BYTE”和“DWORD”定义变量,如果初值相同,则占用的存储空间也一样多。 错。用BYTE只占一个存储单元,而DWORD要占4个存储单元 (5)TYPE DX的结果是一个常量,等于2。 对 (6)IA-32处理器采用小端方式存储多字节数据。 对 (7)某个双字变量存放于存储器地址0403H ~ 0406H中,对齐了地址边界。 错 (8)立即数寻址只会出现在源操作数中。 对 (9)存储器寻址方式的操作数当然在主存了。 对 (10)指令“MOV EAX, VAR+2”与“MOV EAX, VAR[2]”功能相同。 对,仅是不同的形式罢了 2.3 填空题 (1)计算机中有一个“01100001”编码。如果把它认为是无符号数,它是十进制数___________;如果认为它是BCD码,则表示真值_____________;又如果它是某个ASCII码,则代表字符__________。 97,61,小写字母a (2)C语言用“\n”表示让光标回到下一行首位,在汇编语言中需要输出两个控制字符:一个是回车,其ASCII码是_____________,它将光标移动到当前所在行的首位;另一个是换行,其ASCII码是_____________,它将光标移到下一行。 0DH(13),0AH(10) (3)定义字节变量的伪指令助记符是______,获取变量名所具有的偏移地址的操作符是_______。 BYTE,OFFSET (4)数据段有语句“H8843 Dword 99008843h”,代码段指令“mov cx,word ptr h8843”执行后,cx=( )。 8843 (5)用DWORD定义一个变量XYZ,它的类型是( ),用“type XZY”会得到数值为( )。如果将其以字变量使用,应该用( )说明。 双字,4,word ptr (6)数据段有语句“ABC BYTE 1,2,3”,代码段指令“mov cl,abc+2”执行后,cl = ( ). 3 (7)除外设数据外的数据寻址方式有3类,分别称为 (),()和()。 立即寻址,寄存器寻址,存储器寻址 (8)指令“MOV EAX, OFFSET MSG”的目的操作数和源操作数分别采用______和_______寻址方式。 寄存器寻址,立即数寻址 (9)已知ESI=04000H,EBX=20H,指令“MOV EAX, [ESI+EBX*2+8]”中访问的有效地址是__________。 04000H+20H×2+8=04048H (10)用EBX作为及地址指令,默认采用()段寄存器指向的数据段,如果采用BP、EBP或SP、ESP作为基地址指针,默认使用()段寄存器指向堆栈。 DS,SS 习题2.10 按照如下要求定义变量或符号常量: (1) my1b为字符串变量:Personal Computer my1b byte 'Personal Computer' (2) my2b为用十进制数表示的字节变量:20 my2b byte 20 (3) my3b为用十六进制数表示的字节变量:20 my3b byte 14h (4) my4b为用二进制数表示的字节变量:20 my4b byte 00010100b 按照如下要求定义变量或符号常量: (5) my5w为20个未赋值的字变量 my5w word 20 dup(?) (6) my6c为100的常量 my6c = 100 (7) my7c表示字符串:Personal Computer my7c equ <Personal Computer> 习题2.14 按照如下输出格式,在屏幕上显示ASCII表 编程在数据段直接构造这样的表格、填写相应ASCII代码值(不是字符本身),然后使用字符串显示子程序DISPMSG实现显示 .data Table byte 3 dup(20h),’ |0 1 2 3 4 5 6 7 8 9 A B C D E F', 13,10 byte dup(‘-’),’+’,31 dup (‘-’), 13,10 Byte'20|',20h,20h,21h,20h,22h,20h,23h,20h, 24h,20h,25h,20h,26h,20h,27h,20h,28h,20h,29h,20h byte 2ah,20h,2bh,20h,2ch,20h,2dh,20h,2eh,20h, 2fh,20h,13,10 byte '30 |',30h,20h,31h,20h,32h,20h,33h,20h, 34h,20h,35h,20h,36h,20h,37h,20h,38h,20h,39h,20h byte 3ah,20h,3bh,20h,3ch,20h,3dh,20h,3eh,20h, 3fh,20h,13,10 …… byte 0 …… ca ='2' cas =20h byte ca,'0 |',cas,20h,cas+1,20h,cas+2,20h, cas+3,20h,cas+4,20h,cas+5,20h,cas+6,20h,cas+7,20h byte 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 cas =cas+10h ca =ca+1 byte ca,'0 |',cas,20h,cas+1,20h,cas+2,20h, cas+3,20h,cas+4,20h,cas+5,20h,cas+6,20h,cas+7,20h byte 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 习题2.15 数据段有如下定义: var dword 12345678h 现以字节为单位按地址从低到高的顺序,写出这个变量内容。 var变量的内容:78H、56H、34H、12H 并说明如下指令的执行结果: mov eax,var ;EAX=12345678H mov bx,word ptr var ;BX=5678H mov cx,word ptr var+2 ;CX=1234H mov dl,byte ptr var ;DL=78H mov dh,byte ptr var+3 ;DH=12H 习题2.17 说明源操作数的寻址方式 (1)mov edx,1234h 立即数 (2)mov edx,vard 直接 (3)mov edx,ebx 寄存器 (4)mov edx,[ebx] 寄存器间接 (5)mov edx,[ebx+1234h] 寄存器相对 (6)mov edx,vard[ebx] 寄存器相对 (7)mov edx,[ebx+edi] 基址变址 (8)mov edx,[ebx+edi+1234h] 相对基址变址 (9)mov edx,vard[esi+edi] 相对基址变址 (10)mov edx,[ebp*4] 带比例寻址 第三章 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)执行了一条加法指令后,发现ZF=1,说明结果是什么? 表明运算结果为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,所以标志ZF=1。 错,MOV指令不影响标志 (2)空操作NOP指令其实根本没有指令。 错, (3)堆栈的操作原则是“先进后出”,所以堆栈段的数据除了PUSH和POP指令外,不允许其他方式读写。 错 (4)虽然ADD指令和SUB指令执行后会影响标志状态,但执行前的标志并不影响它们的执行结果。 对 (5)80减90(80-90)需要借位,所以执行结束后,进位标志CF=1。 对,减法时借位也用CF标志反映 (6)指令“INC ECX”和“ADD ECX,1”实现的功能完全一样,可以互相替换。 错,INC 不影响CF位。 (7)无符号数在前面加零扩展,数值不变;有符号数前面进行符号扩展,位数加长一位、数值增加一倍。 错,符号扩展也不改变数值大小 (8)CMP 指令是目的操作数减去源操作数,与SUB指令功能相同 错 (9)逻辑运算没有进位或溢出问题,此时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位二进制数加法:BAH+6CH,8位结果是__________,标志PF=__________。如果进行16位二进制数加法:45BAH+786CH,16位结果是__________,标志PF=__________。 26H,0,BE26H,0 (5)已知AX=98H,执行“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=___,CF=OF=___。而指令“MOV EAX, 0”执行后,EAX=___,CF和OF没有变化。 0,0,0 (9)例子3-9 的程序执行结束后,变量qvar的内容是_______ 0123456788765432 (10)欲将EDX内的无符号数除以16,使用指令“SHR EDX, ____”,其中后一个操作数是一个立即数。 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,ax eip为专用寄存器 (3)mov es,1234h 段寄存器不能直接用imm赋值 (4)mov es,ds 段寄存器间不能相互赋值 (5)mov al,300h 位数不同 (6)mov [esi],45h 类型不明确 (7)mov eax,ebx+edi 无该种寻址方式 (8) mov 20h,al 立即数不能做操作数 习题3.6 使用MOV指令实现交换指令“XCHG EBX,[EDI]”功能。 解答: mov eax,ebx mov ebx,[edi] mov [edi],eax 习题3.7 什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应指令是什么。 主存储器中的以“先进后出”规则访问的内存区,入栈、出栈,push ,pop 习题3.11 执行如下程序片断,说明每条指令的执行结果 (1) mov eax,80h add eax,3 add eax,80h adc eax,3 (2) mov eax,100 add ax,200 (3) mov eax,100 add al,200 (包含256的进位含义:256+44=300) (4) mov al,7fh sub al,8 sub al,80h sbb al,3 解答: (1) mov eax,80h ;EAX=80H add eax,3 ;EAX=83H,CF=0,SF=0 add eax,80h ;EAX=103H,CF=0,OF=0 adc eax,3 ;EAX=106H,CF=0,ZF=0 (2) mov eax,100 ;EAX=100(64H) add ax,200 ;EAX=300(12CH),CF=0 (3) mov eax,100 ;EAX=100(64H) add al,200 ;EAX=44(2CH),CF=1 (包含256的进位含义:256+44=300) (4) mov al,7fh ;AL=7FH sub al,8 ;AL=77H,CF=0,SF=0 sub al,80h ;AL=F7H,CF=1,OF=1 sbb al,3 ;AL=F3H,CF=0,ZF=0 习题3.12 给出下列各条指令执行后al的值,以及CF、ZF、SF、OF和PF的状态。 Mov al,89h Add al,al Add al,9dh Cmp al,0bch Sub al,al Dec al Inc al 解答: Mov al,89h ;89h,不影响标志位 Add al,al ;12h,cf=1,zf=0,sf=0,of=1,pf=1 Add al,9dh ;0afh,cf=0,zf=0,sf=1,of=0,pf=1 Cmp al,0bch ;0afh,cf=1,zf=0,sf=1,of=0,pf=1 Sub al,al ;0,cf=0,zf=1,sf=0,of=0,pf=1 Dec al ;ffh,cf=0,zf=0,sf=1,of=0,pf=1 Inc al ;0h,cf=0,zf=1,sf=0,of=0,pf=1 习题3.13 如下两段程序执行后,EDX.EAX寄存器对的值各是多少? (1)加法程序 Mov edx,11h Mov eax,0b0000000h Add eax,040000000h Adc edx,0 (2)减法程序 Mov edx,100h Mov eax,64000000h Sub eax,84000000h Sbb edx,0 解答: (1) EDX=11 EAX=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)把EBX寄存器和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位无符号整数分别存放在变量buffer1和buffer2中,定义数据并编写代码完成edx.eax<- buufer1 - buffer2的功能。 解答: .data Buffer1 qword ? Buffer2 qword ? .code Mov eax,dword ptr buffer1 Mov edx,dword ptr buffer2 + 4 Add eax,dword ptr buffer2 Adc edx,dword ptr buffer2 + 4 习题3.16 执行如下程序片断,说明每条指令的执行结果 (1) mov esi,10011100b ;ESI= _____H and esi,80h ;ESI= _____H or esi,7fh ;ESI= _____H xor esi,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= 9CH and esi,80h ;ESI= 80H or esi,7fh ;ESI= FFH xor esi,0feh ;ESI= 01H (2) mov eax,1010b ;EAX= 1010B(可有前导0) shr eax,2 ;EAX= 0010B,CF=1 shl eax,1 ;EAX= 0100B,CF=0 and eax,3 ;EAX= 0000B,CF=0 (3) mov eax,1011b ;EAX= 1011B(可有前导0) rol eax,2 ;EAX= 101100B,CF=0 rcr eax,1 ;EAX= 10110B,CF=0 or eax,3 ;EAX= 10111B,CF=0 (4) xor eax,eax ;EAX=0,CF=0,OF=0 ;ZF=1,SF=0,PF=1 习题3.17 给出下列各条指令执行后ax的结果,以及状态标志CF、OF、SF、ZF、PF的状态。 Mov ax,1470h And ax,ax Or ax,ax Xor ax,ax Not ax Test ax,0f0f0h 解答: Ax=1470h flags 不变 Ax=1470h cf=of=0 sf=0 zf=0 pf=0 Ax=1470h cf=of=0 sf=0 zf=0 pf=0 Ax=0 cf=of=0 sf=0 zf=1 pf=1 Ax=ffffh flags 不变 Ax=ffffh cf=of=0 sf=1 zf=0 pf=1 习题3.18 举例说明逻辑运算指令怎样实现复位、置位和求反功能。 解答: 复位 使用逻辑与指令and ,例如将al寄存器 D0位复位,指令 and al,0feh 置位 使用逻辑或指令or ,例如将al寄存器 D0位置位,指令 or al,01 求反 使用not指令,例如将ebx寄存器内容求反,指令not ebx 习题3.19 编程将一个压缩BCD码变量(如92h)转换为对应的ASCII码,然后调用dispc字程序(在输入输出字程序中)显示。 解答: .data Bcd1 byte 92h Mov al,bcd1 Shr al,4 Or al,30h Call dispc Mov al,bcd1 And al,0fh Or al,30h Call dispc 习题3.20 有4个32位有符号数,分别保存在var1,var2,var3,var4变量中,阅读如下程序片段,得出运算公式,并说明运算结果存于何处。 Mov eax,var1 Imul var2 Mov ebx,var3 Mov ecx,ebx Sar ecx,32 Add eax,ebx Adc edx,ecx Sub eax,540 Sbb edx,0 Idiv var4 解答: ((var1*var2)+var3-540)/var4,结果存于edx,eax中 习题3.21 如下程序片段实现EAX乘以某个数X的功能,请判断X=? 请使用一条乘法指令实现上述功能。 mov ecx, eax shl eax, 3 lea eax, [eax+eax*8] sub eax, ecx 解答: 8*8+8-1=71 imul eax, 71 习题3.22 请使用移位和加减法指令编写一个程序片段计算:EAX×21,假设乘积不超过32位。提示:21=24+22+20。 解答: mov ebx,eax ;EBX=EAX×20 shl ebx,2 ;EBX=EAX×22 add eax,ebx ;EAX=EAX×(22+20) shl ebx,2 ;EBX=EAX×24 add eax,ebx ;EAX=EAX×(24+22+20) 习题3.23 阅读如下程序,为每条指令添加注释,指出其功能或作用,并说明这个程序运行后显示的结果。如果将程序中的寄存器间接寻址替换为寄存器相对寻址,如何修改程序? .data Num byte 6,7,7,8,3,0,0,0 Tab byte ‘67783000’ .code Mov ecx,lengthof num ; Mov esi,offset num ; Mov edi,offset tab ; Again: Mov al,[esi] ; Xchg al,[edi] ; Mov [esi],al ; Call dispc Add esi,1 ; Add edi,1 ; Loop again 解答: .data Num byte 6,7,7,8,3,0,0,0 Tab byte ‘67783000’ .code Mov ecx,lengthof num ;ecx赋值为num数组长度 Mov esi,offset num ;esi赋值为num偏移地址 Mov edi,offset tab ;edi赋值为tab字符串偏移地址 Again: Mov al,[esi] ;读取num元素到a1 Xchg al,[edi] ;互换al与tab元素 Mov [esi],al ;al存入num数组相应单元 Call dispc Add esi,1 ;指向num下一元素 Add edi,1 ;指向下一字符 Loop again 结果:67783000 修改程序: Mov ecx,lengthof num Xor esi,esi Mov edi,offset tab Again: Mov al,num[esi] Xchg al,num[edi] Mov tab[esi],al Call dispc Add esi,1 Add edi,1 Loop again 习题3.24 说明如下程序执行后的现实结果: .data Msg byte ‘WELLDONE’,0 .code Mov ecx,(lengthof msg) -1 Mov ebx, offset msg Again: Mov al,[ebx] Add al,20h Mov [ebx],al Add ebx,1 Loop again Mov eax,offset msg Call dispmsg 如果将其中的语句“mov ebx,offset msg”改为“xor ebx,ebx”,则利用ebx间接寻址的两个语句如何修改成ebx寄存器相对寻址,就可以实现同样功能? 解答: 修改后程序: Xor ebx,ebx Again: Mov al,msg[ebx] Add al,20h Mov msg[ebx],al Add ebx,1 Loop again 习题3.25 下面程序的功能是将数组array1的每个元素加固定值(8000h),将和保存在数组array2中。在空白处填入适当的语句或语句的一部分。 .data Array1 dword 1,2,3,4,5,6,7,8,9,10 Array2 dword 10 dup(?) .code Mov ecx, lengthof array1 Mov ebx,0 Again: Mov eax,array[ebx*4] Add eax,8000h Mov _______(1)_______ Add ebx,___(2)_________ Loop again 解答: (1) array2[ebx*4],eax (2) 1
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 考试专区 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服