没有合适的资源?快使用搜索试试~ 我知道了~
首页新版钱晓捷主编的汇编课后习题答案
资源详情
资源评论
资源推荐
汇编语言程序设计(第二版) 钱晓捷
习题答案
第二章(01)
2.1
(1)AX=1200h
(2)AX=0100h
(3)AX=4C2Ah
(4)AX=3412h
(5)AX=4C2Ah
(6)AX=7856h
(7)AX=65B7h
2.2(1)两操作数类型不匹配
(2) IP 指令指针禁止用户访问
(3)立即数不允许传给段寄存器
(4)段寄存器之间不允许传送
(5)两操作数类型不匹配
(6)目的操作数应为[ BP ]
(7)源操作数应为 [BX+DI]
(8)立即数不能作目的操作数
2.3
lea bx,table; 获 取 table 的 首 地 址 ,
BX=200H
mov al,8; 传 送 欲 转 换 的 数 字 ,
AL=8
xlat; 转 换 为 格 雷 码 , AL =
12H
2.4
堆栈是一种按“先进后出”原则存取数
据的存储区域。
堆栈的两种基本操作是压栈和出栈,
对应的指令是 PUSH 和 POP。
2.5
mov ax,8057h
push ax
mov ax,0f79h
push ax
pop bx ;bx=0f79h
pop [bx] ;DS:[0f79h]=8057h
2.6
AL=89hCF ZFSF OF PF
AL=12h1 0 0 1 1
AL=0afh 00 1 0 1
AL=0afh1 0 1 0 1
AL=00h01 0 0 1
AL=0ffh 0 01 0 1 AL=00h
0 1 0 0 1
2.7 W=X+Y+24-Z
2.8 (1) ADD DX,BX
(2)ADD AL,[BX+SI]
(3)ADD [BX+0B2H],CX
( 4 ) ADD WORD PTR
[0520H],3412H
(5)ADD AL,0A0H
2.9;为了避免与操作数地址混淆,将
题中 X,Y,Z,V 字操作数改为 A,B,C,D
mov ax,X;ax=A
imul Y; dx,ax = A*B (将
操作数看作符号数,以下同)
mov cx,ax
mov bx,dx; bx,ax<--dx,ax
=A*B
mov ax,Z;ax = C
cwd;dx,ax =C(扩展符号后为
双字)
add cx,ax
adc bx,dx ;
注释 bx,cx<-- bx,cx+dx,ax=A*B+C
sub cx,540
sbb bx,0; bx,cx<-- A*B+C-
540
mov ax, V;ax= D
cwd; dx,ax= D(扩展 符号后为
双字)yy
sub ax, cx
sbb dx, bx
; dx,ax=dx,ax - bx,cx = D-(A*B+C-
540)
idiv X ; 运 算 结 果 : [D-(A*B+C-
540h)]/A ;ax 存商 dx 存余数
2.10;(1)xchg 的操作数不能是立即
数
(2 不能对 CS 直接赋值
(3)两个操作数不能都是存储单元
(4)堆栈的操作数不能是字节量
(5)adc 的操作数不能是段寄存器
(6)没有确定是字节还是字操作
(7)in 不支持超过 FFH 的直接寻址
(8)out 只能以 AL/AX 为源操作数
第二章(02)
2.11;
指令
AX
的值
CF OF SF ZF PF
Mov ax,1407h 1470h- - - - -
And ax,ax 1470h0 0 0 0 0
Or ax,ax 1470h0 0 0 0 0
Xor ax,ax 0 0 0 0 1 1
Not ax 0ffffh - - - - -
Test ax,0f0f0h 0ffffh 0 0 1 0 1
注意: 1. mov, not 指令不影响标志位
2. 其他逻辑指令使 CF=OF=0, 根
据结果影响其他标志位。
第 2 章(03)2.12;
指令注释执行结果yyyCF OF SF ZF PF
Movsi,ax - - - - - si=ax
si=0008h
Shl si,1 0 0 0 0 0
add si,ax0 0 0 0 1
si=3*axsi=0018h
Mov dx,bx- - - - -
dx=bxdx=0010h
Mov cl,03h - - - - -
cl=03h
shl dx,cl 0 u 0 0 0
dx=8*bx dx=0080h
sub dx,bx 0 0 0 0 0
dx=7*bx dx=0070h
add dx,si 0 0 0 0 1
dx=7*bx+3*ax dx=0088h
注意:1. 左移 N 次相当于乘于 2 的 N
次方,右左移 N 次相当于除乘于 2 的
N 次方。
2. 移位指令根据是否移入“1”到 CF,设
置 CF, 根 据 移 位 后 的 结 果 影 响
SF,ZF,PF。根据最高符号位是否改变
设置 OF,如改变 OF=1.
3. ‘ u ’表示无定义,‘ - ’表示无影响。
2.13; (1) ;不考虑进位 mov bl,al
mov cl,3
shl al,cl
add al,bl ;shl bl,1
add al,bl ;考虑进位 xor ah,ah
mov bx,ax
mov cl,3
shl ax,cl
add ax,bx ;shl bx,1
add ax,bx
(2) 数字 0~9 的 ASCII 码是: 30h~
39h
非压缩 BCD 码的 0~9 是:00h~09h
方法一: and al,0fh ;实现 ASCII 到
非压缩 BCD 码的转换
or al,30h ; 实 现 非 压 缩 BCD 码 到
ASCII 的转换
方 法 二 : xor al,30h; 求 反 D5D4
位,其他不变 ;即高 4 位为 3,则变
为 0;高 4 位为 0,则变为 3
mov cl,4
again: shr dx,1 ;实现逻辑右移
;采用“sar dx,1”,则实现算术右移
rcr ax,1
dec cl
jnz again
2.14; (1)用 sar 编写
2.20; 8086 的条件转移的转移范围:在
当前指令地址的 +127---- -128 之内。
如条件转移的转移范围超出此范围,
可在此范围内安排一条无条件转移,
再转移到范围外的目标地址。
2.21; (1)JMP Bx; 转移的 有效地
址 EA=BX=1256h
(2)JMP tABLE[Bx] ;转移的有效地址
EA=[ds:20a1h+1256h]=[232f7]=3280h
(3)JMP [Bx][si]; 转 移 的 有 效 地 址
EA=[ds:1256h+528fh]=264e5h=2450h
2.22; (1) xor ax,1e1eh
je equal
;AX=1e1eh(异或后为 0)
(2)test al,10000001b
jnz there
;AL 的 D0 或 D7 至少有一位为 1
(3) cmp cx,64h
jb there
;CX(无符号数)< 64h
2.23;
mov cx,0不循环,因为一进入循
环就判 cx=0? 如 cx=0 就退出循环
delay:loop delay
2.24; (1)若 DX > DI,转到 above 执
行
cmp dx,di
ja above;=jnbe above
(2)若 AX > SI,转到 greater 执行
cmp ax,si
jg greater;=jnle greater
(3)若 CX = 0,转到 zero 执行
cmp cx,0 jcxz zero
jz zero
( 4 ) 若 AX - SI 产 生 溢 出 , 转 到
overflow 执行;yyyy cmp ax,di
jo overflow
(5)若 SI≤AX,转到 less_eq 执行;
cmp si,ax
cmp ax,si
jle less_eq
jge less_eq
(6)若 DI≤DX,转到 below_eq 执行。
cmp di,dx
cmp dx,di
jbe below_eq
jae below_eq
2.25; 答:将首地址为 array 得 20 个字
的数组求和,并将结果存入 total 单元
中。
2.26; (1) mov si,0
mov dl,string[si];第 1 个字符送 dl 寄
存器
mov si,5
mov dh,string[si]; 第 6 个 字 符 送
dh 寄存器
(2) xor si,si;si 清零
mov al,buffer[si];第一字节
inc si
mov ah,buffer[si];第二字节
mov cl,4
shl ah,cl;BCD 码移到高半字
节
or al,ah;组合成压缩 BCD
码
mov dl,al;存入 dl 寄..
inc si
mov al,buffer[si];第三字节
inc si
mov ah,buffer[si];第四字节
mov cl,4
shl ah,cl;BCD 码移到高半字
节
or al,ah; 组合成 压 缩 BCD
码
mov dh,al;存入 dh 寄..
(3) test dx,0f000h
jz zero
mov ax,-1
jmp done
zero: mov ax,0
done: ret
(4) lea bx,buffer1
lea dx,buffer2
mov cx,8;8 个字节
xor si,si;si=0
clc;CF=0
(5) mov ax,0b800h
mov ds,ax;段地址
xor si,si;地址偏移量 si=0
xor dx,dx;和的高字 dx=0
mov cx,99;加的次数
mov ax,[si];第一个数
again: inc si;指向下一个字单
元
inc si
add ax,[si];加下一个数
jnc noc;无进位转
inc dx;有进位 dx=dx+1
noc: dec cx;次数-1
jnz cx,again;非 0 继续加yy
ret
(6) mov si,offset string
mov cx,8000h;
32k=2^15=8000h
again: cmp [si],’$’
jnz next
mov [si],20h;if [si]=’$’ [si]<-- ’ ’
next: inc si
loop again
(7) xor si,si;si<--0
mov cx,100;循环次数
again: dec array[si]
dec cx
jnz again
(8) xor si,si ;si<--0
coun: cmp string[si],’$’
je done
inc si
jmp coun
done: ret
2..27; (1)使 CF=0 :yyyyyyy clc;yyyyyy
and ax,ax;or ax,ax
(2) 使 AX = 0 : yyyyyy xor ax,ax; yyyy
and ax,0;mov ax,0
(3)同时使 AX=0 和 CF=0: and ax,0
;xor ax,ax ;sub ax,ax
2.29; 压缩 BCD 码 加法: AX←AX+
BX
出口参数:AX=BCD 码和
2.24; okmsg db ‘OK’, ‘$’errmsg
db ‘Error ! Overflow !’, ‘$’ …
mov ax,X
sub ax,Y
jo overflow
mov dx,offset okmsg
jmp next
overflow: mov dx,errmsg
next: mov ah,9
int 21h
错误: mov ax,X
sub ax,Y
jo overflow
mov dx,offset okmsg
okmsg db ‘OK’, ‘$’
mov dx,errmsg ;错误 1:数据定
义在代码中
mov ah,9
int 21h
overflow: errmsg db ‘Error !
Overflow !’, ‘$’
mov dx,errmsg ; 错误 2:缺
少 JMP 指令
mov ah,9
int 21h
2.37; ;xt237.asm
.model small
.stack
.data
array db 255
db 0
array1 db 255 dup('$')
array2 db 0dh,0ah,'$'
.code
.startup
mov ah,0ah ; 键盘输入字符串
mov dx,offset array
int 21h
mov dx,offset array2 ; 回车换行
mov ah,09h
int 21h
mov bx,offset array1
again: mov al,[bx]
cmp al,'$'
jz done
cmp al,'a' ; 小于 a 和大于 z 的字符不
是小写字母
jb next
cmp al,'z'
ja next
sub al,20h ; 在 a 和 z 之间的字符才是
小写字母,转换为大写
mov [bx],al ; 保存到原位置
next: inc bx
jmp again
done: mov dx,offset array1
mov ah,09h
int 21h
.exit 0
end
第三章(01)
3.1; 硬指令:每个硬指令就是一个处
理器指令,在 CPU 执行时产生相应功
能;
伪指令:伪指令并不产生处理器指令,
它通常用于辅助汇编程序对源程序进
行汇编。
3.2;
3.5; ⒈编辑yyyyy文本编辑程序yyyyyy汇编
语言源程序.asm
⒉汇 编 yy汇 编程 序 yyyyyyy目 标 模 块 文
件.obj
⒊连接yyy连接程序yyyy可执行文件.exe
或.com
⒋调试yyyyy调试程序yyyyyyyyyy应用程序
3.6; ;xt236.asm简化段定义格式
.model small ;定义程序的存储
模式(小模式)
.stack; 定 义 堆 栈 段 ( 默 认
1024 个字节)
.data;定义数据段
str1 ab ’Input Number:0~9 :
’,0dh,0ah,’$’
str2 ab ’Error!’,0dh,0ah,’$’
.cade;定义代码段yy
.startup;说明程序的起始点,
建立 ds,ss 的内容。yy
mov ah,09h;显示 str1 字符串
mov dx,offset str1
int 21h
gtekey: mov ah,1;调用 BIOS 判断按
键功能
int 16h
jz getkey;如 zf = 0,无
键按下,等待
cmp al,‘0’;有键按下,键
值与‘0’比较
jb error;如 < ‘0’ ,出错处理
cmp al, ‘9 ’;有键按下,
键值与 ‘9’比较
ja error;如 〉‘ 9’,出错处理
mov ah,02h;调用 DOS 显示
字符功能,显示该数字
mov dl,al
int 21h
.exit 0;终止程序执行,返回
DOS
error: mov ah,09h; 出 错 , 调 用
DOS 功能显示 str2 字符串
mov dx,offset str2
int 21h
jmp getkey;等待按键
end; 汇编结束
3.7; ;xt307.asm
stack segment
dw 512 dup(?)
stack ends
data segment
array db 255
db 0
array1 db 255 dup('$')
array2 db 0dh,0ah,'$'
data ends
code segment 'code'
assume cs:code, ds:data, ss:stack
start: mov ax,data
mov ds,ax
mov ah,0ah ; 键盘输入字符串
mov dx,offset array
int 21h
mov dx,offset array2 ; 回车换行
mov ah,09h
int 21h
mov bx,offset array1
again: mov al,[bx]
cmp al,'$'
jz done
cmp al,'a' ; 小于 a 和大于 z 的字符不
是小写字母
jb next
cmp al,'z'
ja next
sub al,20h ; 在 a 和 z 之间的字符才是
小写字母,转换为大写
mov [bx],al ; 保存到原位置
next: inc bx
jmp again
done: mov dx,offset array1
mov ah,09h
int 21h
mov ax,4c00h
int 21h
code ends
end start
3.9; ( 1 ) mov byte ptr [bx],1000;
1000 超出了一个字节范围
(2) mov bx,offset myword[si];寄存
器的值只有程序执行时才能确定,
;而 offset 是汇编过程计算偏移地
址,故无法确定
;可以改为 lea bx,myword[si]
(3) cmp mybyte1,mybyte2;两个
都是存储单元,指令不允许
(4) mov al,mybyte1+mybyte2 ;变量
值只有执行时才确定,汇编过程不能
计算
( 5 ) sub al,myword; 字 节 量
AL 与字量 myword,类型不匹配
(6) jnz myword;Jcc 指令只
有相对寻址方式,不支持间接寻址方
式
3.10; 前者为“与”操作硬指令助记符,
可汇编成机器代码。
后者为 逻辑运算符 ,在汇编时进行
“与”运算,产生具体数值。
3.11; 注:对于逻辑运算,有关操作数
可化为二进制数。
(1)mov al ,23h AND 45h OR 67h;
67h
(2)mov ax , 1234h/16 + 1Oh;
133h
(3)mov ax , NOT(65535 XOR
1234h); 1234h
(4)mov al, LOW 1234h OR HIGH
剩余13页未读,继续阅读
什么也不想说
- 粉丝: 0
- 资源: 10
上传资源 快速赚钱
- 我的内容管理 收起
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
会员权益专享
最新资源
- 2022年中国足球球迷营销价值报告.pdf
- 房地产培训 -营销总每天在干嘛.pptx
- 黄色简约实用介绍_汇报PPT模板.pptx
- 嵌入式系统原理及应用:第三章 ARM编程简介_3.pdf
- 多媒体应用系统.pptx
- 黄灰配色简约设计精美大气商务汇报PPT模板.pptx
- 用matlab绘制差分方程Z变换-反变换-zplane-residuez-tf2zp-zp2tf-tf2sos-sos2tf-幅相频谱等等.docx
- 网络营销策略-网络营销团队的建立.docx
- 电子商务示范企业申请报告.doc
- 淡雅灰低面风背景完整框架创业商业计划书PPT模板.pptx
- 计算模型与算法技术:10-Iterative Improvement.ppt
- 计算模型与算法技术:9-Greedy Technique.ppt
- 计算模型与算法技术:6-Transform-and-Conquer.ppt
- 云服务安全风险分析研究.pdf
- 软件工程笔记(完整版).doc
- 电子商务网项目实例规划书.doc
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论3