logo资料库

钱晓捷新版汇编语言程序设计习题答案(修改).doc

第1页 / 共15页
第2页 / 共15页
第3页 / 共15页
第4页 / 共15页
第5页 / 共15页
第6页 / 共15页
第7页 / 共15页
第8页 / 共15页
资料共15页,剩余部分请下载后查看
钱晓捷新版汇编语言程序设计习题答案 第一章 汇编语言基础知识 1.1、简述计算机系统的硬件组成及各部分作用 1.2、明确下列概念或符号: 主存和辅存,RAM 和 ROM,存储器地址和 I/O 端口,KB、MB、GB 和 TB 1.3、什么是汇编语言源程序、汇编程序、目标程序? 1.4、汇编语言与高级语言相比有什么优缺点? 1.5、将下列十六进制数转换为二进制和十进制表示 (1)FFH (2)0H (3)5EH (4)EFH (5)2EH (6)10H (7)1FH (8)ABH 1.6、将下列十进制数转换为 BCD 码表示 (1)12 (2)24 (3)68 (4)127 (5)128 (6)255 (7)1234 (8)2458 1.7、将下列 BCD 码转换为十进制数 (1)10010001 (2)10001001 (3)00110110 (4)10010000 (5)00001000 (6)10010111 (7)10000001 (8)00000010 1.8、将下列十进制数分别用 8 位二进制数的原码、反码和补码表示 (1)0 (5)126 (6)-126 (7)-128 (8)68 1.9、完成下列二进制数的运算 (1)1011+1001 (2)1011-1001 (3)1011×1001 (4)10111000÷1001 (5)1011 ∧ ~1011 (8)1011 ⊕ 10011001(6)1011 ∨1001(7) 1.10 数码 0~9、大写字母 A~Z、小写字母 a~z 对应的 ASCII 码分别是多少?ASCII 码 为 0dh、0ah 对应的是什么字符? 1.11、计算机中有一个“01100001”编码,如果把它认为是无符号数,它是 10 进制什么 数?如果认为它是 BCD 码,则表示什么数?又如果它是某个 ASCII 码,则代表哪个字 符? (2)-127 (3)127 (4)-57 1.12、简述 Intel 80x86 系列微处理器在指令集方面的发展。 1.13、什么是 DOS 和 ROM-BIOS? 1.14、简述 PC 机最低 1MB 主存空间的使用情况。 1.15、罗列 8086CPU 的 8 个 8 位和 16 位通用寄存器 ,并说明各自的作用。 1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器 FLAGS,说明各个标志的位置和含义。 1.17、举例说明 CF 和 OF 标志的差异。 第 1 页 共 15 页
溢出标志 OF 和进位标志 CF 是两个意义不同的标志 进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确;溢出标志表示有符 号数运算结果是否超出范围,运算结果已经不正确•例 1:3AH + 7CH=B6H 无符号数运算:58+124=182,范围内,无进位 有符号数运算: 58+124=182 ,范围外,有溢出•例 2:AAH + 7CH=(1)26H 无符号数运算:170+124=294,范围外,有进位 有符号数运算:-86+124=28 ,范围内,无溢出 1.18、字和双字在存储器中如何存放,什么是“小端方式”?对字和双字存储单元,什么 是它们的对齐地址?为什么要对齐地址? 1.19、什么是 8086 中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如 下逻辑地址用物理地址表达: (1)FFFFh:0 (2)40h:17h (3)2000h:4500h (4)B821h:4567h 1.20、8086 有哪 4 种逻辑段,各种逻辑段分别是什么用途?(解答) 代码段(Code Segment)用来存放程序的指令序列。处理器利用 CS : IP 取得下一条要执 行的指令 •堆栈段(Stack Segment)确定堆栈所在的主存区域。处理器利用 SS : SP 操作堆栈中的 数据 •数据段(Data Segment)存放当前运行程序所用的数据。处理器利用 DS : EA 存取数据 段中的数据 •附加段(Extra Segment)是附加的数据段,也用于数据的保存。处理器利用 ES : EA 存 取数据段中的数据 第二章 8086 指令系统 2.1 已知 DS = 2000H、BX = 0100H、SI = 0002H,存储单元[20100H] ~ [20103H]依次存 放 12 34 56 78H,[21200H] ~ [21203H]依次存放 2A 4C B7 65H,说明下列每条指令执行 完后 AX 寄存器的内容。 (1) mov ax,1200h (2) mov ax,bx (3) mov ax,[1200h] (4) mov ax,[bx] (5) mov ax,[bx+1100h] (6) mov ax,[bx+si] (7) mov ax,[bx][si+1100h] ;AX=1200h ; AX=0100h ; AX=4C2Ah ; AX=3412h ; AX=4C2Ah ; AX=7856h ; AX=65B7h 2.2 指出下列指令的错误 (1) mov cx,dl 两操作数类型不匹配 第 2 页 共 15 页
指令指针禁止用户访问 段寄存器之间不允许传送 立即数不允许传给段寄存器 (2) mov ip,ax IP (3) mov es,1234h (4) mov es,ds (5) mov al,300 (6) mov [sp],ax (7) mov ax,bx+di (8) mov 20h,ah 2.3 已知数字 0 ~ 9 对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、 11H、12H、14H,它存在于以 table 为首地址(设为 200H)的连续区域中。请为如下程 序段的每条指令加上注释,说明每条指令的功能和执行结果。 立即数不能作目的操作数 两操作数类型不匹配 目的操作数应为[ BP ] 源操作数应为 [BX+DI] lea mov bx,table ;获取 table 的首地址,BX=200H al,8 ;传送欲转换的数字,AL=8 xlat ;转换为格雷码,AL=12H 2.4 什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令? 堆栈是一种按“先进后出”原则存取数据的存储区域。 堆栈的两种基本操作是压栈和出栈,对应的指令是 PUSH 和 POP。 2.5 已知 SS = FFA0H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和 SP 的内 容如何变化? mov ax,8057h push ax mov ax,0f79h push ax pop bx ;bx=0f79h pop [bx] ;DS:[0f79h]=8057h 2.6 给出下列各条指令执行后 AL 值,以及 CF、ZF、SF、OF 和 PF 的状态: 第 3 页 共 15 页
1 0 SF OF CF ZF 1 0 AL=12h AL=89h AL=0afh 0 1 1 mov al,89h add al,al add al,9dh cmp al,0bch sub al,al dec al inc al 2.7 设 X、Y、Z 均为双字数据,分别存放在地址为 X、X+2;Y、Y+2;Z、Z+2 的 AL=0afh AL=0ffh AL=00h AL=00h 0 1 0 0 0 1 0 0 0 0 1 0 0 1 1 1 0 0 1 1 0 PF 1 1 存储单元中,它们的运算结果存入 W 单元。阅读如下程序段,给出运算公式。 mov ax,X mov dx,X+2 add ax,Y adc dx,Y+2 add ax,24 adc dx,0 sub ax,Z sbb dx,Z+2 mov W,ax mov W+2,dx W=X+Y+24-Z ADD DX,BX AL,[BX+SI] 2.8 请分别用一条汇编语言指令完成如下功能: (1)把 BX 寄存器和 DX 寄存器的内容相加,结果存入 DX 寄存器。 ADD (2)用寄存器 BX 和 SI 的基址变址寻址方式把存储器的一个字节与 AL 寄存器的内容 相加,并把结果送到 AL 中。 (3)用 BX 和位移量 0B2H 的寄存器相对寻址方式把存储器中的一个字和 CX 寄存器的 内容相加,并把结果送回存储器中。 ADD (4)用位移量为 0520H 的直接寻址方式把存储器中的一个字与数 3412H 相加,并把结 果送回该存储单元中。 ADD (5)把数 0A0H 与 AL 寄存器的内容相加,并把结果送回 AL 中。 ADD 2.9;设 X、Y、Z、V 均为 16 位带符号数,分别装在 X、Y、Z、V 存储单元中,阅读 如下程序段,得出它的运算公式,并说明运算结果存于何处。 [0520H],3412H [BX+0B2H],CX AL,0A0H WORD PTR 为了避免与操作数地址混淆,将题中 X,Y,Z,V 字操作数改为 A,B,C,D mov ax,X ;ax=A imul Y ;dx,ax = A*B (将操作数看作符号数,以下同) 第 4 页 共 15 页
mov cx,ax mov mov bx,dx ;bx,ax <-- dx,ax =A*B ax,Z ;ax = C cwd ;dx,ax =C (扩展符号后为双字) add adc cx,ax bx,dx ;bx,cx <-- bx,cx+dx,ax=A*B+C sub cx,540 sbb mov bx,0 ;bx,cx<-- A*B+C-540 ax, V ;ax= D cwd ;dx,ax= D (扩展符号后为双字) sub sbb ax, cx dx, bx ;dx,ax = dx,ax - bx,cx = D-(A*B+C-540) idiv X ;运算结果:[D-(A*B+C-540h)]/A ;ax 存商,dx 存余数 xchg 的操作数不能是立即数 不能对 CS 直接赋值 两个操作数不能都是存储单元 2.10; (1) xchg [si],30h (2 ) pop cs (3) sub [si],[di] (4)push ah (5) adc ax,ds (6) add [si],80h (7) in al,3fch (8) out dx,ah 2.11; 给出下列各条指令执行后的结果,以及状态标志 CF、OF、SF、ZF、PF 的状态。 指令 AX 的值 in 不支持超过 FFH 的直接寻址 out 只能以 AL/AX 为源操作数 堆栈的操作数不能是字节量 adc 的操作数不能是段寄存器 没有确定是字节还是字操作 CF OF SF ZF PF Mov ax,1470h 1470h And ax,ax 1470h Or ax,ax 1470h Xor ax,ax 0 - 0 0 0 - 0 0 0 - 0 0 0 - 0 0 1 - 0 0 1 Not ax 0ffffh - - - - - Test ax,0f0f0h 0ffffh 0 0 1 0 1 注意: 1. mov, not 指令不影响标志位 2. 其他逻辑指令使 CF=OF=0, 根据结果影响其他标志位。 2.12; 假设例题 2.32 的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结 果和各个标志位的状态。 指令 注释 执行结果 CF OF SF ZF PF 第 5 页 共 15 页
si=ax si=2*ax si=3*ax dx=bx cl=03h dx=8*bx dx=7*bx dx=7*bx+3*ax si=0008h si=0010h si=0018h dx=0010h dx=0080h dx=0070h dx=0088h - 0 0 - - 0 0 0 - - - - 0 0 - - 0 0 - - 0 0 - - 0 1 - - u 0 0 0 0 0 0 0 0 0 0 1 mov si,ax shl si,1 add si,ax mov dx,bx mov cl,03h shl dx,cl sub dx,bx add dx,si 注意: 1. 左移 N 次相当于乘于 2 的 N 次方,右左移 N 次相当于除乘于 2 的 N 次方。 2. 移位指令根据是否移入“1”到 CF,设置 CF,根据移位后的结果影响 SF,ZF,PF。根据 最高符号位是否改变设置 OF,如改变 OF=1. 3. ‘ u ’表示无定义,‘ - ’表示无影响。 2.13 编写程序段完成如下要求: (1) 用位操作指令实现 AL(无符号数)乘以 10 ;不考虑进位 mov bl,al mov cl,3 shl al,cl add add al,bl ;shl bl,1 al,bl ;考虑进位 xor ah,ah mov mov bx,ax cl,3 shl ax,cl add ax,bx ;shl bx,1 ax,bx add (2) 用逻辑运算指令实现数字 0 ~ 9 的 ASCII 码与非压缩 BCD 码的互相转换 数字 0~9 的 ASCII 码是:30h~39h 非压缩 BCD 码的 0~9 是:00h~09h 方法一: and al,0fh ;实现 ASCII 到非压缩 BCD 码的转换 or al,30h ;实现非压缩 BCD 码到 ASCII 的转换 第 6 页 共 15 页
方法二: xor al,30h ;求反 D5D4 位,其他不变 ;即高 4 位为 3,则变为 0;高 4 位为 0,则变为 3 mov cl,4 again: shr dx,1 ;实现逻辑右移 ;采用“sar dx,1”,则实现算术右移 rcr ax,1 dec jnz cl again (3) 把 DX:.AX 中的双字右移 4 位 MOV CL, 4 SHR AX, CL MOV BL, DL SHR DX, CL SHL BL, CL OR AH, BL 2.14; 已知 AL = F7H(表示有符号数-9),分别编写用 SAR 和 IDIV 指令实现的除以 2 的程序段,并说明各自执行后,所得的商是什么? (1)用 sar 编写 mov al,0f7h sar al,1 ;-9 送 al ;结果:al=0fbh 即-5 (2)用 idiv 编写 mov al,0f7h ;-9 送 al cbw mov bl,2 idiv bl ;字节符号扩展位字 ;注意除数不可为立即数 ;结果:商为 al=fch ; 余数为 ah=ffh (-1) (-4) 结论:符号数的除法 用 idiv 准确 2.15、已知数据段 500h ~600h 处存放了一个字符串,说明下列程序段执行后的结果: mov si,600h 第 7 页 共 15 页
mov di,601h mov ax,ds mov es,ax mov cx,256 std rep movsb 2.16、说明下列程序段的功能 cld mov ax,0fefh mov cx,5 mov bx,3000h mov es,bx mov di,2000h rep stosw 2.17、指令指针 IP 是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指 令的执行会改变它的值?调试程序 DEBUG 环境下,如何改变 IP 数值? 2.18、控制转移类指令中有哪三种寻址方式? 2.19; 什么是短转移 short jump、近转移 near jump 和远转移 far jump?什么是段内转移 和段间转移?8086 有哪些指令可以实现段间转移? 短转移:指段内-128~127 之间的转移,位移量用一个字节表示 近转移:指段内±32K 之间的转移,位移量用一个字表示 远转移:指段间 1MB 范围的转移 段内转移:指在同一个代码段内的转移,可以是短转移或者近转移 段间转移:指转移到另外一个代码段,就是远转移 8086/8088CPU 的 JMP、CALL 和 INT n 指令可以实现段间转移 2.20; 8086 的条件转移指令的转移范围有多大?实际编程时,你如何处理超出范围的 条件转移? 8086 的条件转移的转移范围:在当前指令地址的 +127---- -128 之内。 如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围 外的目标地址。 第 8 页 共 15 页
分享到:
收藏