文档库 最新最全的文档下载
当前位置:文档库 › 汇编语言课后习题答案---郑晓薇(整理后的)

汇编语言课后习题答案---郑晓薇(整理后的)

汇编语言课后习题答案---郑晓薇(整理后的)
汇编语言课后习题答案---郑晓薇(整理后的)

习题一

1 无符号数: 11010011=211=D3H,01110111=119=77H,10000011=131=83H,00101111=47=2FH,10101010=170=AAH

带符号数:11010011= -45=D3H,01110111=+119=77H,10000011= -125=83H,00101111=+47=2FH,10101010= -86=AAH

2

5E8AH,0BE6H,3DEH,4940H

3

00011101+00110101=01010010=52H=82 01001001+11101000=00110001=31H=49 10111110+01010010=00010000=10H=16 10011010+11110001=10001011=8BH= -117 4

00101001+01010011=01111100+00000110=1 0000010=82H=82

01110011-00100100=01001111-00000110=01001001=49H=49

01100110+00011000=01111110+00000110=1 0000100=84H=84

10010+01110101=00111+00000110

=00111=0207H=207

5 000020A3H,FF94H,00003456H,007FH,FFFFEC00H

6 无符号数:0~65535,0000H~FFFFH;带符号数:-32768~+32767,8000H~7FFFH

7

(1) 38H等于十进制数56,是十进制数56的补码,数字8的ASCII码,十进制数38的压缩BCD码

(2) FFH等于十进制数-1,是带符号数-1的补码,无符号数为255

(3) 5AH等于十进制数90,是十进制数90的补码,大写字母Z的ASCII码

(4) 0DH等于十进制数13,是十进制数13的补码,回车符的ASCII码

8

(1) 108=01101100B=6CH,补码01101100B,压缩BCD码01000,ASCII码313038H (2) 46=00101110B=2EH,补码00101110B,压缩BCD码01000110,ASCII码3436H (3) –15=11110001B=F1H,补码11110001B,ASCII码2D3135H

(4) 254=11110B=00FEH,补码11110B,压缩BCD码10100,ASCII码323534H

9

(1) 56+63=01110111B,CF=0,SF=0,ZF=0,OF=0

(2) 83-45=00100110B,CF=0,SF=0,ZF=0,OF=0

(3) -74+29=11010011B,CF=0,SF=1,ZF=0,OF=0

(4) -92-37=01111111B,CF=1,SF=0,ZF=0,OF=1

10

回车、换行、响铃、ESC键、空格键、、P、p

习题二

9 最少划分为16个逻辑段,最多划分为65536个逻辑段(每段16个字节)

10 CS:IP,DS:BX、SI、DI,ES:BX、SI、DI,SS:SP、BP

11 字节单元保存8位数,字单元保存16位数。根据源操作数的属性确定要访问的是字节单元还是字单元。

12 对于字节单元来说,偶地址和奇地址一样;对于字单元而言,最好用偶地址保存,可减少CPU的访存次数。

13 首单元的物理地址=38AE8H,末单元的物理地址=38AE8H+7FFFH=40AE7H

16 (1)物理地址=27679H (2) 物理地址=20F92H (3) 物理地址=20F92H

(2)和(3)的物理地址是一样的。说明逻辑地址不唯一,多个逻辑地址可对应到同一个物理单元上。

17 代码段CS:IP的物理地址

=55A84H 堆栈段SS:SP的物理地址=4DB65H 数据段DS:BX的物理地址=17678H 附加段ES:DI的物理地址=2BA41H

18 当前栈指针所指单元的物理地址是1522CH。堆栈区中还能保存254个字。

19 执行E 200

20 执行U 100

21 执行R CX,然后输入100

22 执行E DS:0 ‘a’ ‘b’ ‘c’ ‘d’

习题三

3MOV AX,BX 源操作数为寄存器寻址,EA 无,物理地址无

MOV AX,1290H 立即寻址,EA 无,物理地址无

MOV AX,[BX] 寄存器间接寻址,EA=1290H, 物理地址=2FBB0H

MOV AX,DS:[1290H] 直接寻址,EA=1290H, 物理地址=2FBB0H

MOV AX,[BP] 寄存器间接寻址,EA=6756H, 物理地址=26A56H

MOV [DI][BX],AX 目的操作数为基址变址寻址,EA=3C06H, 物理地址=32526H

MOV ES:[SI],AX 寄存器间接寻址,EA=348AH, 物理地址=50CAAH

7

MOV AX,[CX] 错。CX不能为间址寄存器MOV AL,1200H 错。立即数超出8位寄存器

MOV AL,BX 错。两个操作数不匹配

MOV [SI][DI],AX 错。两个变址寄存器不能在一起

MOV ES:[DX],CX 错。DX不能为间址寄存器MOV [AX],VALUE 错。AX不能为间址寄存器MOV COUNT,[SI] 错。两个操作数不能都是

存储单元

8

(1) MOV AX,BX (2) MOV CL,15 (3) ADD AX,[BX]

(4) MOV [BX+SI],AL (5) MOV AX,VALUE[SI] (6) SUB AX,DS:[2000H]

9

(1) ADD AX,[X+4]

MOV Y,AX

(2) MOV BX,4

ADD AX,X[BX]

MOV Y,AX

(3) MOV BX,4

MOV SI,OFFSET X

ADD AX,[BX+SI]

MOV Y,AX

10 立即寻址方式中操作数(立即数)和

指令一起存放在代码段中。

习题四10

(1) DATA SEGMENT

X DW 0

Y DW 0

DATA ENDS

(2) STRING DB ’Computer’

(3) COUNT DB 100 DUP(?)

(4) PI EQU 3.14

(5) VALUE LABEL BYTE

11 (1)对。(2)错。260超出了字节围。(3)错。X3是字节型,1234H是字型,不匹配。

(4)对。(5)错。缺少DUP。(6)对。12 (1)AL=3。(2)AX=2103H。(3)DX=TABLE 的偏移地址。(4)CL=33H

(5)BX=TABLE的段地址。(6)BX=1。(7)DX= TABLE的偏移地址。

13

MOV DX,2012H

MOV AX,5D68H

MOV CX,1003H

MOV BX,49A6H

ADD AX,BX (SUB AX,BX)

ADC DX,CX (SBB DX,CX)

14 SUB AX,CX

SBB DX,0

15 MOV AX,extra

MOV ES,AX

16

(1) MOV AL,16

ADD AL,X

MOV BL,5

IMUL BL

MOV Z,AX

(2) MOV BL,4

MOV AL,X

IDIV BL

SUB AL,Y

MOV Z,AX

(3) MOV AL,X

MOV BL,8

IMUL BL

MOV DX,AX

MOV AH,0

MOV AL,Y

MOV BL,16

IDIV BL

CBW

ADD DX,AX

MOV AH,0

MOV AL,W

IMUL AL

SUB DX,AX

MOV Z,DX

(4) MOV AL,X

ADD AL,Y

MOV BL,X

SUB BL,Y

MOV AH,0

IMUL BL

MOV Z,AX

MOV AL,X

IDIV Y

CBW

SUB Z,AX

17 Z= (5+22-15)*14= 168

18 从伪指令END START处获知程序从START标号开始。

19 (1)减

法:

(2) 加法:

MOV

AX,8576H

MOV AX,8576H MOV

BX,9988H

MOV BX,9988H

SUB

AX,BX

ADD AX,BX

结果:

AX=EBEEH 结果:AX=1EFEH

CF=1,OF=0,ZF=0,SF=1 CF=1,OF=1,ZF=0,SF=0

21 (1) MOV AL,56H

MOV BL,34H

ADD AL,BL

DAA

MOV Y1,AL

(2) MOV AX,128H

MOV BX,35H

SUB AX,BX

DAS

MOV Y2,AL

(3) MOV AL,68H

MOV BL,23H

ADD AL,BL

MOV BL,45H

SUB AL,BL

DAS

MOV Y3,AL

22

(1) MOV AX,0708H

MOV BX,0406H

ADD AL,BL

ADD AH,BH ;不用带进位加

AAA ;加法调整,含进位调整

MOV BX,AX

XCHG AH,AL ;高4位调整

AAA

MOV BH,AL

MOV Z1,BX ;保存十位、各位,百位在CF中(2) MOV AX,0905H

MOV BX,0207H

SUB AL,BL

SUB AH,BH ;不用带借位减

AAS ;减法调整

MOV Z2,AX

(3) MOV AX,0102H

MOV BX,0006H

MUL BX ;乘法先不用调整

MOV BX,0303H

SUB AX,BX

AAS ;减法调整

MOV Z3,AX

(4) MOV AX,0704H

MOV BX,0108H

ADD AL,BL

ADD AH,BH

AAA ;加法调整

MOV BL,6

AAD ;除法调整

DIV BL

MOV BH,AH ;余数保存在BH AND AX,000FH

AAA ;商调整

MOV Z4,AX ;保存商

23

.model small

.data

buff db ?

.code

start:

mov ax,data

mov ds,ax

mov ah,1 ;键盘输入

int 21h

sub al,30h ;去掉ASCII码mov buff,al

mov ah,4ch

int 21h

end start

24

.model small

.code

start:

mov ah,1 ;键盘输入

int 21h

sub al,20h ;变为大写

mov dl,al

mov ah,2

int 21h

mov ah,4ch

int 21h

end start

25

.model small

.data

x db 12h

y db 34h

.code

start: mov ax,data

mov ds,ax

mov al,x

add al,y ;结果为46H

mov ah,al ;AH=46H

and al,0fh ;AL=06H

mov cl,4

rol ah,cl ;AH=64H

and ah,0fh ;AH=04H

add ax,3030h ;AX=3436H

mov bx,ax

mov dl,bh ;显示4

mov ah,2

int 21h

mov dl,bl ;显示6

int 21h

mov ah,4ch

int 21h

end start

26

data segment

x db

'0.000','1.000','1.414','1.732','2.00 0'

db

'2.236','2.449','2.646','2.828','3.00 0' ;建立字符表

y db 5 dup(?) ;存放查到平方根

u db 3 ;要查的数

data ends

code segment

assume cs:code,ds:data

start:

mov ax,data

mov ds,ax

mov al,u ;要查的数

mov cl,5

mul cl ;u*5=15(号单元开始)

mov ah,0

mov bx,ax ;地址保存到bx

mov si,0

let1:

mov al,x[bx] ;取出平方根数字

mov y[si],al ;存入y

inc si

inc bx

loop let1 ;循环取出5次

mov ah,4ch

int 21h

code ends

end start

27

.model small

.data

x1 db 'zhang yan $' ;为10个字符宽度x2 db 'li li $'

x3 db 'wang lan $'

x4 db 'zhao xue $'

x5 db 'li jiang $'

u db 3 ;要查的学号

.code

start:

mov ax,data

mov ds,ax

mov al,u ;给出学号

mov cl,10

mul cl ;u*10=30(号单元开始)

mov ah,0

mov dx,ax ;地址保存到dx

mov ah,9 ;9号功能显示字符串

int 21h

mov ah,4ch

int 21h

end start

28 编程实现公式计算Z=X/4+16Y。.model small

.data

x db 4

y db 6

z db ?

.code

start:

mov ax,data

mov ds,ax

mov al,x ;

mov cl,2

sar al,cl ; X/4

mov cl,4 mov bl,y

sal bl,cl ;16Y

add al,bl ;X/4+16Y

mov z,al

mov ah,4ch

int 21h

end start

29

.model small

.data

y db ?,?

.code

start:

mov ax,data

mov ds,ax

mov al,3 ;设al=3

mov cl,6

mul cl ;al*6

mov cl,4 ;设cl=4

sub al,cl ;相减

mov bl,3

idiv bl ; /3

mov y,al ;商

mov y+1,ah ;余数

mov ah,4ch

int 21h

end start

习题五

11 进位标志CF=1

12 先把AX的值除以8等于0246H,再把高12位屏蔽为0,剩下AL=06H加上30H

变为ASCII码显示出来。

13

判断X>0,是,Z=X-Y;否则Z=X的绝对值

14 (1) 目的操作数是存储单元时,要用PTR伪操作指出单元的属性(2)DS

段寄存器使用非法(3)立即数使用非法 (4) 目的操作数不允许是立即数 (5) 两个操作

数不允许都是存储单元 (6)移位次数超过1要用CL表示。

15 AND AL,11011111B

16 (1) AL=30H (2) AL=B7H (3) AL=C8H (4)AL=38H

27 分支程序设计。完成如下公式的计算,请写出程序。

(X+3)/2 X>0

Y=

0 X=0

X×4 X <0

程序如下:

DATA SEGMENT

X DB 23

Y DB ?

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA

START:MOV AX,DATA

MOV DS,AX

MOV AL,X

CMP AL,0

JE SUB2

JG SUB1

MOV CL,2

SAL AL,CL

JMP SHORT SUB2

SUB1:ADD AL,3

SAR AL,1

SUB2: MOV Y,AL

MOV AH,4CH

INT 21H

CODE ENDS

END START

28

设X、Y、Z为字节单元。如果X≥0,

Z=4X-Y/16,否则,Z=X的绝对值。编程序实现。

程序如下:

DATA SEGMENT

X DB 3

Y DB 5

Z DB ?

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA

START: MOV AX,DATA

MOV DS,AX MOV AL,X

CMP AL,0

JL SS1

MOV CL,2

SAL AL,CL

MOV BL,Y

MOV CL,4

SAR BL,CL

SUB AL,BL

JMP OUT1

SS1: NEG AL

OUT1: MOV Z,AL

MOV AH,4CH

INT 21H

CODE ENDS

END START

29 字数组M中有10个数据,分类统计其中正数、负数、0的个数,分别存入POSI、NEGA、ZERO 单元。

程序如下:

DATA1 SEGMENT

M DW 21,-34,32,112,-324,0,76,0,48,50 POSI DW ?

NEGA DW ?

ZERO DW ?

DATA1 ENDS

CODE1 SEGMENT

ASSUME CS: CODE1,DS:DATA1

START: MOV AX,DATA1

MOV DS,AX

MOV CX,10

LEA SI,M

AGAIN: CMP WORD PTR [SI],0

JL LOWER

JE EQUAL

INC POSI

JMP LPP1

LOWER: INC NEGA

JMP LPP1

EQUAL: INC ZERO

LPP1: ADD SI,2

DEC CX

JNZ AGAIN

MOV AH,4CH

INT 21H

CODE1 ENDS

END START

30 试编写程序,从键盘接收一英文单词,以空格结束,将其存入BUF开始的存储单元中,并在最后加上字符串结束符’$’。主要程序部分:

LEA BX,BUF

LOP: MOV AH,1

INT 21H

CMP AL,20H

JE NEXT

MOV [BX],AL

INC BX

JMP LOP

NEXT: MOV BYTE PTR[BX],’$’

31

编程。将AX寄存器中的16位数分成4组,每组4位,从低到高分别放在AL,BL,CL,DL中。

程序段:

START:MOV AX,1234H

MOV BX,AX

AND AL,0FH ;4

AND BL,0F0H ;3

AND AH,0FH

MOV CL,AH ;2

AND BH,0F0H

MOV DL,BH ;1

习题六

11累加和TOTAL=83

12 循环统计X中0的个数

13

(1) 将BB1:RCL AL,1改为BB1:ROL AL,1

(2) 将BB2:CMP [BX],’T’

LOOPNE BB2

改为:

DEC BX

BB2:INC BX

CMP [BX],’T’

LOOPNE BB2

15 计算

Y=1×2+3×4+5×6+7×8+9×10的程序段答案:MOV AL,1

MOV BL,2

MOV DX,0

MOV CX,5

AA1:MUL BL

ADD DX,AX

INC BL

MOV AL,BL

INC BL

LOOP AA1

16 写程序段。查找CATT表中的字符””,找到后将SIGN单元置1,否则SIGN 单元置0。

catt db 'asdddd'

sign db ?

……

mov ax,extra

mov es,ax

mov sign,0

mov al,''

lea di,catt

cld

mov cx,7

repnz scasb

jcxz nee

mov sign,1

nee: mov ah,4ch

int 21h

17 写程序段。在长度为N的字数组VALUE中统计负数的个数并保存到AX中。value dw 2,-4,-5,3,6,6,-8

n equ ($-value)/2 ;元素个数

……

start: mov ax,data

mov ds,ax

mov cx,n

mov bx,0

mov ax,0

rept1:

mov si,value[bx] ;取出元素

cmp si,0

jge let1 ;≥0 转let1

inc ax ;为负数,ax加1

let1: add bx,2

loop rept1

18 从键盘输入一个数字,在屏幕上显示出以该数字开始10个数字串。

CODE SEGMENT

ASSUME CS:CODE

START: MOV AH,1

INT 21H

MOV CX,10

MOV BL,AL

REPT1: CMP BL,'9'

JLE NEXT

SUB BL,10

NEXT: MOV DL,BL

MOV AH,2

INT 21H

INC BL

LOOP REPT1

MOV AH,4CH

INT 21H

CODE ENDS

END START

19

data segment

bunch1 db 'stadent'

bunch2 db 'studEnt'

data ends

code segment

assume cs:code,ds:data,es:data start:

mov ax,data

mov ds,ax

mov es,ax

lea si,bunch1

lea di,bunch2

mov bx,0 ;bh=相同的个数,bl=不同的个数mov cx,7

let1:

mov al,[si]

cmp al,[di] ;两字符比较

jz equl ;相同转equl

inc bl ;不同bl加1

jmp out1

equl: inc bh out1:inc si

inc di

loop let1

mov dl,'n' ;显示'n',代表不同mov ah,2h

int 21h

add bl,30h ;加上ASCII码mov dl,bl ;显示不同的个数

int 21h

mov dl,'e' ;显示'e',代表相同int 21h

add bh,30h

mov dl,bh ;显示相同的个数

int 21h

mov ah,4ch

int 21h

code ends

end start

21

DATA SEGMENT

STR DB ‘SDABF G H0’

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA START:MOV AX,DATA

MOV DS,AX

LEA DI,STR

SPACE:MOV CX,10

MOV AL,[DI]

CMP AL,0

JE OUT

CMP AL,20H

JE DELETE

JMP EXIT

SUB CX,DI

MOV SI,DI

DELETE:

MOV BL,[SI+1]

MOV [SI],BL

INC SI

LOOP DELETE

EXIT:JMP SPACE

OUT:MOV AH,4CH

INT 21H

CODE ENDS

END START

23 设计思路:

(1)用EQU伪指令获得需转换的十进制数的个数;

(2)用双重循环。外循环控制个数,用x 作为中间变量;

(3)循环将一个3位十进制数去掉ASCII 码后按位数扩大10倍再相加,保存后即存储为二进制数;

(4)分两个数组保存ASCII码表示的十进制数和转换后的二进制数。

程序如下:

; 6-23.asm 将存中用ASCII码表示的100以的十进制数转变为二进制数

data segment

score1 db

36h,37h,20h,31h,30h,30h,38h,35h,20h,3 1h,30h,30h ;即67,100,85,100

x dw ?

n equ 3 ;三位数

num equ (x-score1)/n ;十进制数个数score2 dw num dup(0) ;保存转换后的二进制数

data ends

code segment

assume cs:code,ds:data

start: mov ax,data

mov ds,ax

mov cx,num

mov si,-2

mov bx,0

rept1: push cx ;保存外循环次数

mov cx,n

rept2: mov al,score1[bx] ;从score1取数

cmp al,30h ;判断是否0-9

jl exit

cmp al,39h

jg exit

and ax,000fh ;去掉ASCII码

xchg ax,x

mov dx,10 ;将ax中前一次形成的数扩大10倍

mul dx

xchg ax,x

add x,ax ;相加后保存到x

exit: inc bx ;取下一位数

loop rept2

pop cx ;弹出外循环次数

add si,2

mov ax,x

mov score2[si],ax ;转换后的数据保存到score2

mov x,0

loop rept1

mov ah,4ch

int 21h

code ends

end start

习题七

12 功能:两个字节数相加。X和BL相加保存到Y。

13 功能:键盘输入的字符保存到KEY 单元中,直到按回车为止。

14 功能:将X单元中的十六进制3AH 变为十进制入栈保存,AH中为余数。先将0008H入栈,再将0005H入栈,结果为58。

16

PUSH AX

PUSH BX

MOV BX,0

LET1:MOV AH,1

INT 21H

CMP AL,0DH ;输入回车退出

JZ EXIT

MOV BUFFER[BX],AL ;保存到BUFFER

INC BX

JMP LET1

EXIT:POP BX

POP AX

RET

KEY_IN ENDP

17

KEY_IN_DEC PROC

PUSH AX

PUSH BX

MOV X,0

MOV BX,0

MOV SI,0

LET1:MOV AH,1

INT 21H

CMP AL,0DH ;输入回车退出

JZ EXIT

MOV BUFFER[SI],AL ;保存到BUFFER INC SI

JMP LET1

EXIT:MOV CX,SI ;位数放在CX MOV SI,0

LET2:MOV AL, BUFFER[SI]

SUB AL,30H

MOV AH, 0

XCHG AX,X ;形成十进制数

MOV BX,10

MUL BX

XCHG AX,X

ADD X,AX ;保存

INC SI

LOOP LET2

POP BX

POP AX

RET

KEY_IN _DEC ENDP

23

calcu proc

push ax

push bx

push si

mov ax,0

mov al,x

and al,al

jns zz

neg al

mov fuhao,'-'

zz:

mov si,0

mov bx,10 ;将ax变为十进制数真值let1:

mov dx,0

inc si ;统计余数个数

idiv bx mov y[si], dx ;在y单元保存余数cmp ax,0

jnz let1

pop si

pop bx

pop ax

ret

calcu endp

30

DATA SEGMENT

A D

B 9,-8,-7,6,5

B DB -8,7,6,-5,4

SUM1 DB ?

SUM2 DB ?

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA START:MOV AX,DATA

MOV DS,AX

MOV CX,5

MOV SI,OFFSET A

CALL LADD

MOV SUM1,BL

MOV SI,OFFSET B

CALL LADD

MOV SUM2,BL

MOV AH,4CH

INT 21H

LADD PROC NEAR

PUSH CX

PUSH AX

PUSH SI

XOR BL,BL

NEXT: MOV AL, [SI]

AND AL,AL

JNS JJJ

ADD BL,AL

JJJ: INC SI

LOOP NEXT

POP SI

POP AX

POP CX

RET

LADD ENDP

CODE ENDS

END START

习题八

16 宏的作用:DOS功能调用。功能号用哑元指出。

17 宏的作用:两个操作数相加,结果保存在第3个数中。

18 宏的作用:DOS的2号显示功能。

19 宏的作用:定义VALUE数组,数组长度和初值由哑元指出。

20

缺少标号定义LOCAL LETT1。宏的作用:两个哑元相减,结果为负则求补。

27 程序:

.model small

.stack 100h

.code

start:

input ;键盘输入

add al,20h ; 大写变为小写

output al ; 显示

mov ah,4ch

int 21h

end start

28 程序:

.model small

.data

alpha db ‘Computer’

.code

start:

display alpha ;显示字串

mov ah,4ch

int 21h

end start

29 程序:

.model small

.stack 100h

.code

start:

input ;键盘输入

cmp al,‘-’

jnz start

neg x ;求补

mov ah,4ch int 21h

end start

30 程序:

.model small

.stack 100h

.code

start:

input ;键盘输入

mov bl,al

input ;输入第2个数

add al,bl

mov ah,0

aaa ;非压缩BCD码加法调整add ax,3030h

output ah ;显示高位output al ;显示低位

mov ah,4ch

int 21h

end start

汇编语言课后习题答案

2.1已知DS=2000H、BX=0100H、SI=0002H,存储单元[20100H]~[20103H]依次存放12345678H,[21200H]~[21203H]依次存放2A4C B765H,说明下列每条指令执行完后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] 〔解答〕 (1)AX=1200H (2)AX=0100H (3)AX=4C2AH;偏移地址=bx=0100h (4)AX=3412H;偏移地址=bx=0100h (5)AX=4C2AH;偏移地址=bx+1100h=1200h (6)AX=7856H;偏移地址=bx+si=0100h+0002h=0102h (7)AX=65B7H;偏移地址=bx+si+1100h=0100h+0002h+1100h=1202h 〔习题2.2〕指出下列指令的错误 (1)mov cx,dl (2)mov ip,ax (3)mov es,1234h (4)mov es,ds (5)mov al,300 (6)mov[sp],ax (7)mov ax,bx+di

(8)mov20h,ah 〔解答〕 (1)两操作数类型不匹配 (2)IP指令指针禁止用户访问 (3)立即数不允许传给段寄存器 (4)段寄存器之间不允许传送 (5)两操作数类型不匹配 (6)目的操作数应为[SI] (7)源操作数应为[BX+DI] (8)立即数不能作目的操作数 〔习题2.5〕已知SS=2200H、SP=00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?mov ax,8057h push ax mov ax,0f79h push ax pop bx pop[bx] 〔解答〕 mov ax,8057h push ax mov ax,0f79h push ax pop bx;bx=0f79h pop[bx];DS:[0f79h]=8057h

汇编语言课后习题解答

第1章基础知识 检测点1.1(第9页) (1)1个CPU的寻址能力为8KB,那么它的地址总线的宽度为13位。 (2)1KB的存储器有1024个存储单元,存储单元的编号从0到1023。 (3)1KB的存储器可以存储8192(2^13)个bit,1024个Byte。 (4)1GB是1073741824(2^30)个Byte、1MB是1048576(2^20)个Byte、1KB是1024(2^10)个Byte。 (5)8080、8088、80296、80386的地址总线宽度分别为16根、20根、24根、32根,则它们的寻址能力分别为: 64(KB)、1(MB)、16(MB)、4(GB)。 (6)8080、8088、8086、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根。则它们一次可以传送的数据为: 1(B)、1(B)、2(B)、2(B)、4(B)。 (7)从内存中读取1024字节的数据,8086至少要读512次,80386至少要读256次。 (8)在存储器中,数据和程序以二进制形式存放。

(1)1KB=1024B,8KB=1024B*8=2^N,N=13。 (2)存储器的容量是以字节为最小单位来计算的,1KB=1024B。 (3)8Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。 (4)1GB=1073741824B(即2^30)1MB=1048576B(即2^20)1KB=1024B(即2^10)。(5)一个CPU有N根地址线,则可以说这个CPU的地址总线的宽度为N。这样的CPU 最多可以寻找2的N次方个内存单元。(一个内存单元=1Byte)。 (6)8根数据总线一次可以传送8位二进制数据(即一个字节)。 (7)8086的数据总线宽度为16根(即一次传送的数据为2B)1024B/2B=512,同理1024B/4B=256。 (8)在存储器中指令和数据没有任何区别,都是二进制信息。

汇编语言 第二版 王爽 完整答案

第1章基础知识 检测点1.1 (1)1个CPU的寻址能力为8KB,那么它的地址总线的宽度为13。 (2)1KB的存储器有1024个存储单元。存储单元的编号从0到1023。 (3)1KB的存储器可以存储1024*8个bit,1024个Byte。 (4)1GB、1MB、1KB分别是2^30、2^20、2^10 Byte。(n^m的意思是n的m次幂) (5)8080、8088、80286、80386的地址总线宽度分别是16根、20根、24根、32根,则它们的寻址能力分别为:64(KB)、1(MB)、16(MB)、4(GB)。 (6)8080、8088、8086、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根。则它们一次可以传送的数据为:1(B)、1(B)、2(B)、2(B)、4(B)。 (7)从内存中读取1024字节的数据,8086至少要读512次、80386至少要读256次。 (8)在存储器中,数据和程序以二进制形式存放。 第2章寄存器答案 检测点2.1 (1) 写出每条汇编指令执行后相关寄存器中的值。 mov ax,62627 AX=F4A3H mov ah,31H AX=31A3H mov al,23H AX=3123H add ax,ax AX=6246H mov bx,826CH BX=826CH mov cx,ax CX=6246H mov ax,bx AX=826CH add ax,bx AX=04D8H mov al,bh AX=0482H mov ah,bl AX=6C82H add ah,ah AX=D882H add al,6 AX=D888H add al,al AX=D810H mov ax,cx AX=6246H (2) 只能使用目前学过的汇编指令,最多使用4条指令,编程计算2的4次方。 解: mov ax,2 add ax,ax add ax,ax add ax,ax 检测点2.2 (1) 给定段地址为0001H,仅通过变化偏移地址寻址,CPU的寻址范围为00010H到1000FH。 (2) 有一数据存放在内存 20000H 单元中,先给定段地址为SA,若想用偏移地址寻到此单元。

汇编语言程序设计(钱晓捷)课后答案

汇编语言程序设计(第二版) 钱晓捷习题答案 第二章(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=89h CF ZF SF OF PF AL=12h 1 0 0 1 1 AL=0afh 0 0 1 0 1 AL=0afh 1 0 1 0 1 AL=00h 0 1 0 0 1 AL=0ffh 0 0 1 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 (扩展符号后为双字) 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,1407h1470h----- And ax,ax1470h00000 Or ax,ax1470h00000 Xor ax,ax000011 Not ax0ffffh----- Test ax,0f0f0h0ffffh00101 注意: 1. mov, not指令不影响标志位 2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位。

《汇编语言与接口技术》答案习题解答(第三章)

解: mov ah,1 ;只允许输入小写字母 int 21h sub al,20h ;转换为大写字母 mov dl,al mov ah,2 int 21h ;显示 解: mov ax, bufX cmp ax, bufY jge done mov ax, bufY done: mov bufZ, ax 解:

.model small .stack .data bufX dw -7 signX db .code .startup cmp bufX,0 ;test bufX,80h jl next ;jnz next mov signX,0 jmp done next: mov signX,-1 done: .exit 0 end 解: mov dl,’2’ mov ax,bufX cmp ax,bufY je next1 dec dl next1: cmp ax,bufZ je next2 dec dl next2: mov ah,2 int 21h

编制程序完成12H、45H、0F3H、6AH、20H、0FEH、90H、0C8H、57H和34H等10个字节数据之和,并将结果存入字节变量SUM中(不考虑溢出和进位)。 ; .model small .stack .data b_data db 12h,45h,0f3h,6ah,20h,0feh,90h,0c8h,57h,34h ;原始数据num equ 10 ;数据个数 sum db ;预留结果单元 .code .startup xor si, si ;位移量清零 xor al, al ;取第一个数 mov cx, num ;累加次数 again: add al, b_data[si] ;累加 inc si ;指向下一个数 loop again ;如未完,继续累加 mov sum, al ;完了,存结果 .exit 0 end 解: lucase proc push bx mov bx,offset string cmp al,0 je case0 cmp al,1

汇编语言课后习题答案___郑晓薇(整理后的)

习题一 1 无符号数: 11010011=211=D3H,01110111=119=77H, 10000011=131=83H, 00101111=47=2FH, 10101010=170=AAH 带符号数:11010011= -45=D3H,01110111=+119=77H,10000011= -125=83H, 00101111=+47=2FH,10101010= -86=AAH 2 5E8AH,0BE6H,3DEH,4940H 3 00011101+00110101=01010010=5 2H=82 01001001+11101000=00110001=3 1H=49 10111110+01010010=00010000=1 0H=16 10011010+11110001=10001011=8 BH= -117 4 00101001+01010011=01111100+0 0000110=10000010=82H=82 01110011-00100100=01001111-00000110=01001001=49H=49 01100110+00011000=01111110+0 0000110=10000100=84H=84 0000000100110010+01110101=00 00000110100111+00000110 =0000001000000111=0207H=207 5 000020A3H,FF94H,00003456H,007FH,FFFFEC00H 6 无符号数:0~65535,0000H~FFFFH;带符号数:-32768~+32767,8000H~7FFFH 7 (1) 38H等于十进制数56,是十进制数56的补码,数字8的ASCII码,十进制数38的压缩BCD码 (2) FFH等于十进制数-1,是带符号数-1的补码,无符号数为255 (3) 5AH等于十进制数90,是十进制数90的补码,大写字母Z的ASCII码 (4) 0DH等于十进制数13,是十进制数13的补码,回车符的ASCII码 8 (1) 108=01101100B=6CH,补码01101100B,压缩BCD码0000000100001000,ASCII码313038H (2) 46=00101110B=2EH,补码00101110B,压缩BCD码01000110,ASCII码3436H (3) –15=11110001B=F1H,补码11110001B,ASCII码2D3135H (4) 254=0000000011111110B=00FEH,补码0000000011111110B,压缩BCD 码0000001001010100,ASCII码323534H 9 (1) 56+63=01110111B,CF=0,SF=0,ZF=0,OF=0 (2) 83-45=00100110B,CF=0,SF=0,ZF=0,OF=0 (3) -74+29=11010011B,CF=0, SF=1,ZF=0,OF=0 (4) -92-37=01111111B,CF=1, SF=0,ZF=0,OF=1 10 回车、换行、响铃、ESC键、空格键、@、P、p 习题二 9 最少划分为16个逻辑段,最多划分为65536个逻辑段(每段16个字节) 10 CS:IP,DS:BX、SI、DI,ES:BX、SI、DI,SS:SP、BP 11 字节单元保存8位数,字单元保存16位数。根据源操作数的属性确定要访问的是字节单元还是字单元。 12 对于字节单元来说,偶地址和奇地址一样;对于字单元而言,最好用偶地址保存,可减少CPU的访存次数。 13 首单元的物理地址=38AE8H,末单元的物理地址 =38AE8H+7FFFH=40AE7H

汇编语言程序设计课后习题解答宋人杰2版

第1章汇编语言基础知识 1.简述汇编语言源程序、汇编程序、和目标程序的关系。 答:用汇编语言编写的程序称为汇编源程序;汇编源程序在汇编程序的翻译下转换成计算机语言变成目标程序。 2. 简述汇编语言的优缺点。 答:(1) 汇编语言的优点: ①可有效地访问、控制计算机各种硬件设备,如磁盘、存储器、CPU、I/O端口等。. ②目标代码简短,占用内存少,执行速度快,是高效的程序设计语言。 ③可与高级语言配合使用,应用十分广泛。 (2) 汇编语言的缺点: ①通用性和可移植性较差 ②相对于高级语言来说较繁锁、易出错、不够直观。 3.CPU的寻址能力为8KB,那么它的地址总线的宽度为多少? 答:13 4. 1KB的存储器有多少个存储单元? 答:1024个字节。 5. 指令中的逻辑地址由哪两部分组成? 答:指令中的逻辑地址由段基址和偏移量组成。 6. 以下为用段基址:偏移量形式表示的内存地址,试计算它们的物理地址。 (1) 12F8:0100 (2) 1A2F:0103 (3) 1A3F:0003 (4) 1A3F:A1FF 答: (1) 13080H (2) 1A3F3H (3) 1A3F3H (4) 245EFH 7. 自12FA:0000开始的内存单元中存放以下数据(用十六进制形式表示): 03 06 11 A3 13 01,试分别写出12FA:0002的字节型数据、字型数据及双字型数据 的值。 答:字节型数据:11H 字型数据:0A311H 双字型数据:0113A311H 8. 内存中某单元的物理地址是19318H,段基地址为1916H,则段内偏移地址为 多少?若段内偏移地址为2228H,则段基地址为多少? 答:若段基地址为1916H,则段内偏移地址为01B8H;若段内偏移地址为2228H,则段基地址为170FH 9. 在实模式环境中,一个段最长不能超过多少字节? 答:64KB 10. 实模式可寻址的内存范围是多少? 答:1MB

汇编语言课后习题答案郑晓薇后的

汇编语言课后习题答案郑 晓薇后的 Modified by JEEP on December 26th, 2020.

习题一1 2 5E8AH,0BE6H,3DEH,4940H 3 00011101+00110101=0101001 0=52H=82 4 5000020A3H,FF94H,00003456H,007FH, FFFFEC00H 6无符号数:0~65535,0000H~FFFFH;带符号数:-32768~ +32767,8000H~7FFFH 7 (1) 38H等于十进制数56,是十进制数56的补码,数字8的ASCII 码,十进制数38的压缩BCD码(2) FFH等于十进制数-1,是带符号数-1的补码,无符号数为255(3) 5AH等于十进制数90,是十进制数90的补码,大写字母Z的ASCII码(4) 0DH等于十进制数13,是十进制数13的补码,回车符的ASCII码8 (2) 46=00101110B=2EH,补码00101110B,压缩BCD码01000110,ASCII码3436H 9 (1) 56+63=01110111B, CF=0,SF=0,ZF=0,OF=0(2) 83-45=00100110B,CF=0, SF=0,ZF=0,OF=0(4) -92-37=01111111B,CF=1,SF=0,ZF=0,OF=1 10 回车、换行、响铃、ESC键、空格键、@、P、p 习题二 9 最少划分为16个逻辑段,最多划分为65536个逻辑段(每段16个字节) 10CS:IP,DS:BX、SI、DI,ES:BX、SI、DI,SS:SP、BP 11 字节单元保存8位数,字单元保存16位数。根据源操作数的属性确定要访问的是字节单元还是字单元。

汇编语言程序设计习题答案

第一章. 习题 1.1用降幂法和除法将下列十进制数转换为二进制数和十六进制数: (1) 369 (2) 10000 (3) 4095 (4) 32767 答:(1) 369=1 0111 0001B=171H (2) 10000=10 0111 0001 0000B=2710H (3) 4095=1111 1111 1111B=FFFH (4) 32767=111 1111 1111 1111B=7FFFH 1.2将下列二进制数转换为十六进制数和十进制数: (1) 10 1101 (2) 1000 0000 (3) 1111 1111 1111 1111 (4) 1111 1111 答:(1) 10 1101B=2DH=45 (2) 1000 0000B=80H=128 (3) 1111 1111 1111 1111B=FFFFH=65535 (4) 1111 1111B=FFH=255 1.3将下列十六进制数转换为二进制数和十进制数: (1) FA (2) 5B (3) FFFE (4) 1234 答:(1) FAH=1111 1010B=250 (2) 5BH=101 1011B=91 (3) FFFEH=1111 1111 1111 1110B=65534 (4) 1234H=1 0010 0011 0100B=4660 1.4完成下列十六进制数的运算,并转换为十进制数进行校核: (1) 3A+B7 (2) 1234+AF (3) ABCD-FE (4) 7AB×6F 答:(1) 3A+B7H=F1H=241 (2) 1234+AFH=12E3H=4835 (3) ABCD-FEH=AACFH=43727 (4) 7AB×6FH=35325H=217893 1.5下列各数均为十进制数,请用8位二进制补码计算下列各题,并用十六进制数表示其 运算结果。 (1) (-85)+76 (2) 85+(-76) (3) 85-76 (4) 85-(-76) (5) (-85)-76 (6) -85-(-76) 答:(1) (-85)+76=1010 1011B+0100 1100B=1111 0111B=0F7H;CF=0;OF=0 (2) 85+(-76)=0101 0101B+1011 0100B=0000 1001B=09H;CF=1;OF=0 (3) 85-76=0101 0101B-0100 1100B=0101 0101B+1011 0100B=0000 1001B=09H;CF=0; OF=0 (4) 85-(-76)=0101 0101B-1011 0100B=0101 0101B+0100 1100B=10100001B=0A1H; CF=0;OF=1 (5) (-85)-76=1010 1011B-0100 1100B=1010 1011B+1011 0100B=0101 1111B=5FH; CF=0;OF=1 (6) -85-(-76)=1010 1011B-1011 0100B=1010 1011B+0100 1100B=11110111B=0F7H; CF=0;OF=0 1.6下列各数为十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的 带符号数或无符号数时,它们所表示的十进制数是什么?

汇编语言课后习题答案 王爽主编

补全编程,利用jcxz指令,实现在内存2000H段中查找第一个值为0的字节,找到后,将它的偏移地址存储在dx中。 assume cs:code code segment start: mov ax,2000h mov ds,ax mov bx,0 s: mov ch,0 mov cl,[bx] jcxz ok ;当cx=0时,CS:IP指向OK inc bx jmp short s ok: mov dx,bx mov ax ,4c00h int 21h code ends end start 检测点9.3 补全编程,利用loop指令,实现在内存2000H段中查找第一个值为0的字节,找到后,将它的偏移地址存储在dx中。 assume cs:code code segment start: mov ax,2000h mov ds,ax mov bx,0 s:mov cl,[bx] mov ch,0 inc cx inc bx loop s ok:dec bx mov dx,bx mov ax,4c00h int 21h code ends end start 书P101,执行loop s时,首先要将(cx)减1。 “loop 标号”相当于 dec cx if((cx)≠0) jmp short 标号 检测点10.1 补全程序,实现从内存1000:0000处开始执行指令。 assume cs:code stack segment db 16 dup (0) stack ends code segment start: mov ax,stack mov ss,ax mov sp,16 mov ax, 1000h

《汇编语言》第二版习题答案(全)

教材:《汇编语言》 检测点1.1 (1)1个CPU的寻址能力为8KB,那么它的地址总线的宽度为 13位。 (2)1KB的存储器有 1024 个存储单元,存储单元的编号从 0 到 1023 。 (3)1KB的存储器可以存储 8192(2^13)个bit, 1024个Byte。 (4)1GB是 1073741824 (2^30)个Byte、1MB是 1048576(2^20)个Byte、1KB是 1024(2^10)个Byte。 (5)8080、8088、80296、80386的地址总线宽度分别为16根、20根、24根、32根,则它们的寻址能力分别为: 64 (KB)、 1 (MB)、 16 (MB)、 4 (GB)。 (6)8080、8088、8086、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根。则它们一次可以传送的数据为: 1 (B)、 1 (B)、 2 (B)、 2 (B)、 4 (B)。 (7)从内存中读取1024字节的数据,8086至少要读 512 次,80386至少要读 256 次。 (8)在存储器中,数据和程序以二进制形式存放。 解题过程: (1)1KB=1024B,8KB=1024B*8=2^N,N=13。 (2)存储器的容量是以字节为最小单位来计算的,1KB=1024B。 (3)8Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。 (4)1GB=1073741824B(即2^30)1MB=1048576B(即2^20)1KB=1024B(即2^10)。 (5)一个CPU有N根地址线,则可以说这个CPU的地址总线的宽度为N。这样的CPU最多可以寻找2的N 次方个内存单元。(一个内存单元=1Byte)。 (6)8根数据总线一次可以传送8位二进制数据(即一个字节)。 (7)8086的数据总线宽度为16根(即一次传送的数据为2B)1024B/2B=512,同理1024B/4B=256。(8)在存储器中指令和数据没有任何区别,都是二进制信息。 检测点 2.1 (1) 写出每条汇编指令执行后相关寄存器中的值。 mov ax,62627 AX=F4A3H mov ah,31H AX=31A3H mov al,23H AX=3123H add ax,ax AX=6246H mov bx,826CH BX=826CH mov cx,ax CX=6246H mov ax,bx AX=826CH add ax,bx AX=04D8H mov al,bh AX=0482H mov ah,bl AX=6C82H add ah,ah AX=D882H add al,6 AX=D888H add al,al AX=D810H mov ax,cx AX=6246H Microsoft(R) Windows DOS

《汇编语言》习题及解答

第1章基础知识 检测点(第9页) (1)1个CPU的寻址能力为8KB,那么它的地址总线的宽度为13位。 (2)1KB的存储器有1024个存储单元,存储单元的编号从0到1023。 (3)1KB的存储器可以存储8192(2^13)个bit,1024个Byte。 ~ (4)1GB是24(2^30)个Byte、1MB是1048576(2^20)个Byte、1KB是1024(2^10)个Byte。 (5)8080、8088、80296、80386的地址总线宽度分别为16根、20根、24根、32根,则它们的寻址能力分别为: 64(KB)、1(MB)、16(MB)、4(GB)。 (6)8080、8088、8086、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根。则它们一次可以传送的数据为: 1(B)、1(B)、2(B)、2(B)、4(B)。 (7)从内存中读取1024字节的数据,8086至少要读512次,80386至少要读256次。 (8)在存储器中,数据和程序以二进制形式存放。 解题过程: ' (1)1KB=1024B,8KB=1024B*8=2^N,N=13。 (2)存储器的容量是以字节为最小单位来计算的,1KB=1024B。 (3)8Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。 (4)1GB=24B(即2^30)1MB=1048576B(即2^20)1KB=1024B(即2^10)。 (5)一个CPU有N根地址线,则可以说这个CPU的地址总线的宽度为N。这样的CPU最多可以寻找2的N次方个内存单元。(一个内存单元=1Byte)。 (6)8根数据总线一次可以传送8位二进制数据(即一个字节)。 (7)8086的数据总线宽度为16根(即一次传送的数据为2B)1024B/2B=512,同理1024B/4B=256。 (8)在存储器中指令和数据没有任何区别,都是二进制信息。

汇编语言课后习题答案 郑晓薇

习题一 1分别将下列二进制数作为无符号数和带符号数转换为十进制和十六进制数 ,01110111,,00101111 , 查看正确答案 无符号数: =211=D3H,01110111=119=77H,=131=83H, 00101111=47=2FH,=170=AAH 带符号数:= -45=D3H,01110111=+119=77H,= -125=83H, 00101111=+47=2FH,= -86=AAH 2十六进制运算 1A52H+4438H ,3967H-2D81H,37H×12H ,1250H×4H 查看正确答案 5E8AH,0BE6H,3DEH,4940H 3将十进制数变为8位补码,做运算(结果用二进制、十六进制、十进制表示) 29+53,73-24,-66+82 ,-102-15 查看正确答案 00011101+00110101=01010010=52H=82 01001001+=00110001=31H=49 +01010010=00010000=10H=16 +==8BH= -117 4用压缩BCD码计算(结果用二进制、BCD码、十进制表示) 29+53,73-24,66+18 ,132+75 查看正确答案 00101001+01010011=01111100+00000110==82H=82 01110011-00100100=01001111-00000110=01001001=49H=49 01100110+00011000=01111110+00000110==84H=84 00000000+01110101=00000001+00000110 =00000011=0207H=207 5符号位扩展(字节扩展为字,字扩展为双字) 20A3H,94H ,3456H ,7FH ,EC00H 查看正确答案 000020A3H,FF94H,00003456H,007FH,FFFFEC00H 6若机器字长为16位,其无符号数表示范围是多少带符号数表示范围是多少分别用十进制和十六进制表示。查看正确答案 无符号数:0~65535,0000H~FFFFH;带符号数:-32768~+32767,8000H~7FFFH 7写出下列十六进制数所能代表的数值或编码: (1)38H (2)FFH (3)5AH (4)0DH 查看正确答案

汇编语言课后习题答案---郑晓薇(整理后的)doc资料

汇编语言课后习题答案---郑晓薇(整理后 的)

习题一 1 无符号数: 11010011=211=D3H,01110111=119=77H,10000011=131=83H,00101111=47=2FH,10101010=170=AAH 带符号数:11010011= - 45=D3H, 01110111=+119=77H,10000011= -125=83H,00101111=+47=2FH,10101010= -86=AAH 2 5E8AH,0BE6H,3DEH,4940H 3 00011101+00110101=0101001 0=52H=82 01001001+11101000=0011000 1=31H=49 10111110+01010010=0001000 0=10H=16 10011010+11110001=1000101 1=8BH= -117 4 00101001+01010011=0111110 0+00000110=10000010=82H= 82 01110011- 00100100=01001111-00000110=01001001=49H=49 01100110+00011000=0111111 0+00000110=10000100=84H= 84 0000000100110010+01110101 =0000000110100111+0000011 0 =0000001000000111=0207H= 207 5 000020A3H,FF94H,00003456H,007FH,FFFFEC00H 6 无符号数:0~65535, 0000H~FFFFH;带符号数:-32768~+32767,8000H~ 7FFFH 7 (1) 38H等于十进制数56,是十进制数56的补码,数字8的ASCII 码,十进制数38的压缩BCD码(2) FFH等于十进制数-1,是带符号数-1的补码,无符号数为255 (3) 5AH等于十进制数90,是十进制数90的补码,大写字母Z的ASCII码

汇编语言程序设计(第四版)第2章【课后答案】汇总

汇编语言程序设计第四版 【课后习题答案】--囮裑為檤 第2章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] 〔解答〕 (1)AX=1200H (2)AX=0100H (3)AX=4C2AH ;偏移地址=bx=0100h (4)AX=3412H ;偏移地址=bx=0100h (5)AX=4C2AH ;偏移地址=bx+1100h=1200h (6)AX=7856H ;偏移地址=bx+si=0100h+0002h=0102h (7)AX=65B7H ;偏移地址=bx+si+1100h=0100h+0002h+1100h=1202h 〔习题2.2〕指出下列指令的错误 (1)mov cx,dl (2)mov ip,ax (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 〔解答〕 (1)两操作数类型不匹配 (2)IP指令指针禁止用户访问 (3)立即数不允许传给段寄存器 (4)段寄存器之间不允许传送 (5)两操作数类型不匹配 (6)目的操作数应为[ SI ] (7)源操作数应为[BX+DI] (8)立即数不能作目的操作数 〔习题2.3〕已知数字0 ~ 9对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址(设为200H)的连续区域中。请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。 lea bx,table mov al,8 xlat 〔解答〕 lea bx,table ;获取table的首地址,BX=200H mov al,8 ;传送欲转换的数字,AL=8 xlat ;转换为格雷码,AL=12H P35 〔习题2.4〕什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令? 〔解答〕 堆栈是一种按“先进后出”原则存取数据的存储区域,位于堆栈段中,使用SS段寄存器记录其段地址;它的工作原则是先进后出;堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。 〔习题2.5〕已知SS = 2200H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化? mov ax,8057h push ax mov ax,0f79h push ax

汇编语言练习题及习题答案

选择 1、用户为了解决自己的问题,用汇编语言所编写的程序,称为___________。 A 、目标程序B、源程序C、可执行程序D、汇编程序 2、无论BH中原有的数是奇数或偶数,若要使BH中的数一定为奇数,应执行的指令是___________。 A、ADD BH,01H B、OR BH,01H C、XOR BH,01H D、TEST BH,01H 3、设AL=20H,SI=0500H,DS=3000H,(30500H)=0C0H,CF=1,执行SBB AL,[SI]后,正确的结果是___________。 A、AL=5FH SF=1 CF=1 B、AL=60H SF=1 CF=0 C、AL=5FH SF=0 CF=1 D、AL=60H SF=0 CF=0 4、设AX=1000H NEG AX NOT AX 执行上述指令后,正确的结果是___________。 A、AX=1001H B、AX=0FFFH C、AX=1000H D、AX=0111H 5、CBW指令的功能是___________。 A、把源操作数的符号位扩展到目的操作数中 B、把AL中的符号位扩展到AH中 C、把AH中的符号位扩展到AL中 D、把AX中的符号位扩展到DX中 6、AND,OR,XOR,NOT为四条逻辑运算指令,下面的解释正确的是 A、指令XOR AX,AX执行后,AX内容不变,但设置了标志位 B、指令OR DX,1000H执行后,将DX最高位置1,其余各位置0 C、指令AND AX,OFH执行后,分离出AL低四位 D、NOT AX,执行后,将AX清0 7、执行下列指令序列后,正确的结果是___________。 MOV AL,81H ADD AL,AL ADC AL,AL A、AL=05H B、AL=204H C、AL=04H D、AL=205H 4、TEST DL,55H JE NEXT …. NEXT:…… 上述程序段,执行JE指令时能产生转移的情况是。 A、DL>55H B、DL<55H C、DL=55H D、DL中第0、2、4、6位均为0 5、设CL=05H,要获得CL=0AH,可选用的指令是。 A、XOR CL,0FH B、NOT CL C、OR CL,0AH D、AND CL,0FH 填空

汇编语言(王爽)第二版课后题全答案

add ah,ah AX=D882H add al,6 AX=D888H add al,al AX=D810H mov ax,cx AX=6246H Microsoft(R) Windows DOS (C)Copyright Microsoft Corp 1990-2001. C:\DOCUME~1\ADMINI~1>debug -a 0C1C:0100 mov ax,f4a3 0C1C:0103 mov ah,31 0C1C:0105 mov al,23 0C1C:0107 add ax,ax 0C1C:0109 mov bx,826c 0C1C:010C mov cx,ax 0C1C:010E mov ax,bx 0C1C:0110 add ax,bx 0C1C:0112 mov al,bh 0C1C:0114 mov ah,bl 0C1C:0116 add ah,ah 0C1C:0118 add al,6 0C1C:011A add al,al 0C1C:011C mov ax,cx 0C1C:011E -r AX=0000 BX=0000 CX=0000 DX=0000 SP=FFEE BP=0000 SI=0000 DI=0000 DS=0C1C ES=0C1C SS=0C1C CS=0C1C IP=0100 NV UP EI PL NZ NA PO NC 0C1C:0100 B8A3F4 MOV AX,F4A3 -t AX=F4A3 BX=0000 CX=0000 DX=0000 SP=FFEE BP=0000 SI=0000 DI=0000 DS=0C1C ES=0C1C SS=0C1C CS=0C1C IP=0103 NV UP EI PL NZ NA PO NC 0C1C:0103 B431 MOV AH,31 -t AX=31A3 BX=0000 CX=0000 DX=0000 SP=FFEE BP=0000 SI=0000 DI=0000 DS=0C1C ES=0C1C SS=0C1C CS=0C1C IP=0105 NV UP EI PL NZ NA PO NC

汇编语言习题及答案

汇编语言复习题 简答题 1.存储器地址为什么要分段?物理地址是如何形成的? 2.IBM PC机的寻址方式(与数据有关的寻址方式)有几种?各举一例说明。 3.80x86微机的存储器中存放信息如下图所示。试读出30022H与30024H字节单元的内容与30021H和30022H字单元的内容。 4.现有(DS)= 2000H,(BX)=0100H,(SI)= 0002H, (20100)= 12H, (20101)=34H, (20102)= 56H, (20103)=78H, (21200)=2AH, (21201)= 4CH, (21202)=B7H, (21203) = 65H,试说明下列各条指令执行完后AX的内容。 1)MOV AX,1200H

2)MOV AX,BX 3)MOV AX,[1200H] 4)MOV AX,[BX] 5)MOV AX,1100[BX] 5.完成下列各式补码数的运算,并根据结果设置标志位SF,CF,ZF,OF,指出运算结果是否有效 1)01001001b+10011101b 2)01000001b-10101011b 6.有符号定义语句如下: BUFF DB 1,2,3,’123’ EBUFF DB 0 L EQU EBUFF-BUFF 问L的值为多少?为什么? 答案: 1、IBM PC系列机的字长为16位,能够访问的最大存储空间64KB,而在IBM PC内存为1MB的情况下,访问这1MB的存储空间需要20位。为了解决字长为16位的机器访问1MB的存储空间,将1MB空间每16B

分为一段,共64K段,以16位段地址:16位偏移地址的形式组成,物理地址通过如下方式计算: 物理地址=段地址×10h + 偏移地址 2.IBM PC机的寻址方式有7种: 1)立即寻址:MOV AX, 1234H; 2)寄存器寻址:MOV AX, BX; 3)直接寻址:MOV AX, [1234H]; 4)寄存器间接寻址:MOV AX, [BX]; 5)寄存器相对寻址:MOV AX, 20H[BX]; 6)基址变址寻址:MOV AX, [BX][SI]; 7)相对基址变址寻址:MOV AX, 100H[BX][SI]; 3.解:(30022H)= 12H (30024H) = 56H (30021H) = 12CDH (30022H) = 3412H 4.解: (1)MOV AX,1200H 解:(AX)=1200H (2)M OV AX,BX 解:(AX)= 0100H

相关文档
相关文档 最新文档