汇编语言程序设计课后答案

时间:2026-01-16

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指令指针禁止用户访问

(1)ADD DX,BX

(3) 立即数不允许传给段寄存器

(2)ADD AL,[BX+SI]

(4) 段寄存器之间不允许传送

(3)ADD [BX+0B2H],CX

(5) 两操作数类型不匹配

(4)ADD WORD PTR [0520H],3412H

(6) 目的操作数应为[ BP ]

(5)ADD AL,0A0H

(7) 源操作数应为 [BX+DI]

2.9;为了避免与操作数地址混淆,将

(8) 立即数不能作目的操作数

题中X,Y,Z,V 字操作数改为A,B,C,D

2.3

mov ax,X ;ax=A

lea bx,table ;获取table的首地址,

imul Y ;dx,ax = A*B (将

BX=200H

操作数看作符号数,以下同)

mov al,8 ;传送欲转换的数字,

mov cx,ax

AL=8

mov bx,dx ;

xlat ;转换为格雷码,AL=12H

bx,ax <-- dx,ax =A*B

2.4

mov ax,Z ;ax = C

mov ax,8057h

cwd ;dx,ax =C (扩展符

push ax

号后为双字)

mov ax,0f79h

add cx,ax

push ax

adc bx,dx ;bx,cx <--

pop bx ;bx=0f79h

bx,cx+dx,ax=A*B+C

pop [bx] ;DS:[0f79h]=8057h

sub cx,540

2.6

sbb bx,0 ;bx,cx<--

AL=89h CF ZF SF OF

A*B+C-540

PF

mov ax, V ;ax= D

AL=12h 1 0 0 1

cwd ;dx,ax= D (扩展符

1

号后为双字)

AL=0afh 0 0 1 0

sub ax, cx

1

sbb dx, bx ;dx,ax = dx,ax - bx,cx

AL=0afh 1 0 1 0

= D-(A*B+C-540)

1

idiv X ;运算结果:

AL=00h 0 1 0 0

[D-(A*B+C-540h)]/A ;ax存商,dx存

1

余数

AL=0ffh 0 0 1 0

1

AL=00h 0 1 0 0 1

堆栈是一种按“先进后出”原则存取数据的存储区域。

堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。 2.5

2.7 W=X+Y+24-Z 2.8

2.10;(1)xchg的操作数不能是立即数 (2不能对CS直接赋值

(3)两个操作数不能都是存储单元 (4)堆栈的操作数不能是字节量 (5)adc的操作数不能是段寄存器 (6)没有确定是字节还是字操作 (7)in不支持超过FFH的直接寻址 (8)out只能以AL/AX为源操作数 第二章(02)

2. 其他逻辑指令使

CF=OF=0, 根据结果影响其他标志位。 第2章(03) 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执行; 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 …… 此处隐藏:13763字,全部文档内容请下载后查看。喜欢就下载吧 ……

汇编语言程序设计课后答案.doc 将本文的Word文档下载到电脑

    精彩图片

    热门精选

    大家正在看

    × 游客快捷下载通道(下载后可以自由复制和排版)

    限时特价:4.9 元/份 原价:20元

    支付方式:

    开通VIP包月会员 特价:19元/月

    注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
    微信:fanwen365 QQ:370150219