文档库 最新最全的文档下载
当前位置:文档库 › 汇编语言程序设计习题答案

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

第一章. 习题

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

(5) (-85)-76=1010 1011B-0100 1100B=1010 1011B+1011 0100B=0101 1111B=5FH;CF=0;OF=1

1.6下列各数为十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的带符号数或无符

号数时,它们所表示的十进制数是什么?

(1) D8 (2) FF

答:(1) D8H表示的带符号数为 -40,D8H表示的无符号数为216;

(2) FFH表示的带符号数为 -1, FFH表示的无符号数为255。

1.7下列各数均为用十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的数或字符的

ASCII码时,它们所表示的十进制数及字符是什么?

(1) 4F (2) 2B (3) 73 (4) 59

答:(1) 4FH表示的十进制数为 79,4FH表示的字符为O;

(2) 2BH表示的十进制数为 43,2BH表示的字符为 +;

(3) 73H表示的十进制数为115,73H表示的字符为s;

(4) 59H表示的十进制数为89,59H表示的字符为Y。

1.8请写出下列字符串的ASCII码值。

For example,

This is a number 3692.

答:46H 6FH 72H 20H 65H 78H 61H 6DH 70H 6CH 65H 2CH 0AH 0DH

54H 68H 69H 73H 20H 69H 73H 20H 61H 20H 6EH 75H 6DH 62H 65H 72H 20H 33H 36H 39H 32H 2EH 0AH 0DH

第 二 章. 习 题

2.1 在80x86微机的输入/输出指令中,I/O 端口号通常是由DX 寄存器提供的,但有时也可以在指令中直接

指定00~FFH 的端口号。试问可直接由指令指定的I/O 端口数。 答:可直接由指令指定的I/O 端口数为256个。 2.2 有两个16位字1EE5H 和2A3CH 分别存放在80x86微机的存储器的000B0H 和

000B3H 单元中,请用图表示出它们在存储器里的存放情况。 答:存储器里的存放情况如右上图所示。 2.3 在IBM PC 机的存储器中存放信息如右下图所示。试读出30022H 和30024H

字节单元的内容,以及30021H 和30022H 字单元的内容。

答:30022H 字节单元的内容为ABH ;30024H 字节单元的内容为EFH 。30021H

字单元的内容为AB34H ;30022H 字单元的内容为CDABH 。 2.4 在实模式下,段地址和偏移地址为3017:000A 的存储单元的物理地址是什

么?如果段地址和偏移地址是3015:002A 和3010:007A 呢? 答:3017:000A 、3015:002A 和3010:007A 的存储单元的物理地址都是3017AH 。 2.5 如果在一个程序开始执行以前(CS)=0A7F0H ,(如16进制数的最高位为字母,则应在其前加一个0) (IP)=2B40H ,试问该程序的第一个字的物理地址是多少?

答:该程序的第一个字的物理地址是0AAA40H 。

2.6 在实模式下,存储器中每一段最多可有10000H 个字节。如果用调试程序DEBUG 的r 命令在终端上显示出当前各寄存器的内容如下,请画出此时存储器分段的示意图,以及条件标志OF 、SF 、ZF 、CF 的值。

C>debug

-r

AX=0000 BX=0000 CX=0079 DX=0000 SP=FFEE BP=0000 SI=0000 DI=0000 DS=10E4 ES=10F4 SS=21F0 CS=31FF IP=0100 NV UP DI PL NZ NA PO NC 答:此时存储器分段的示意图如右图所示。OF 、SF 、ZF 、CF 的值都为0。 2.7 下列操作可使用那些寄存器? (1) 加法和减法 数据寄存器等

(2) 循环计数

CX

(3) 乘法和除法

AX 、DX ,乘数和除数用其他寄存器

或存储器

(4) 保存段地址 段寄存器 (5) 表示运算结果为0 ZF=1 (6) 将要执行的指令地址 CS:IP (7) 将要从堆栈取出数据的地址 SS:SP

答:答案见题目的右边。

2.8 那些寄存器可以用来指示存储器地址?

答:BX 、BP 、SI 、DI 、堆栈操作时的SP 、对应的段地址、386及其后继机型的Exx 。

2.9 请将下列左边的项和右边的解释联系起来(把所选字母放在括号中):

(1) CPU (M) A.保存当前栈顶地址的寄存器。 (2) 存储器 (C) B.指示下一条要执行的指令的地址。 (3) 堆栈 (D) C.存储程序、数据等信息的记忆装置,微机有RAM 和ROM 两种。 (4) IP (B) D.以后进先出方式工作的存储空间。 (5) SP (A) E.把汇编语言程序翻译成机器语言程序的系统程序。 (6) 状态标志 (L) F.唯一代表存储空间中每个字节单元的地址。 (7) 控制标志 (K) G.能被计算机直接识别的语言。 (8) 段寄存器 (J) H.用指令的助记符、符号地址、标号等符号书写程序的语言。 (9) 物理地址 (F) I.把若干个模块连接起来成为可执行文件的系统程序。 (10) 汇编语言 (H) J.保存各逻辑段的起始地址的寄存器,8086/8088机有四个:CS 、DS 、

SS 、ES 。

34H 30021H ABH 30022H CDH 30023H EFH

30024H

存储器 2.3题的信息存放情况

12H 30020H E5H 000B0H 1EH 000B1H 3CH 000B3H 2AH

000B4H 存储器 2.2题的信息存放情况

… 000B2H

10F40 10E40 20F40

20E40 21F00 31F00 31FF0

41FF0

附加段 数据段

堆栈段 代码段 2.6 题的存储器分段示意图

(11) 机器语言(G) K.控制操作的标志,如DF位。

(12) 汇编程序(E) L.记录指令操作结果的标志,共6位:OF、SF、ZF、AF、PF、CF。

(13) 连接程序(I) M.分析、控制并执行指令的部件,由算术逻辑部件ALU和寄存器等

组成。

(14) 指令(O) N.由汇编程序在汇编过程中执行的指令。

(15) 伪指令(N) O.告诉CPU要执行的操作(一般还要指出操作数地址),在程序运行时

执行。

答:答案见题目的括号中。

第三章. 习题

3.1给定(BX)=637DH,(SI)=2A9BH,位移量D=7237H,试确定在以下各种寻址方式下的有效地址是什么?

(1) 立即寻址

(2) 直接寻址

(3) 使用BX的寄存器寻址

(4) 使用BX的简接寻址

(5) 使用BX的寄存器相对寻址

(6) 基址变址寻址

(7) 相对基址变址寻址

答:(1) 操作数在指令中,即立即数;

(2) EA=D=7237H;

(3) 无EA,操作数为(BX)=637DH;

(4) EA=(BX)=637DH;

(5) EA=(BX)+D=0D5B4H;

(6) EA=(BX)+(SI)=8E18H;

(7) EA=(BX)+(SI)+D=1004FH;超过了段的边界,最高进位位丢失,因此EA=004FH。

3.2试根据以下要求写出相应的汇编语言指令

(1) 把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器中。

(2) 用寄存器BX和SI的基址变址寻址方式把存储器中的一个字节与AL寄存器的内容相加,并把结果

送到AL寄存器中。

(3) 用寄存器BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和(CX)相加,并把结果送

回存储器中。

(4) 用位移量为0524H的直接寻址方式把存储器中的一个字与数2A59H相加,并把结果送回存储单元

中。

(5) 把数0B5H与(AL)相加,并把结果送回AL中。

答:(1) ADD DX, BX

(2) ADD AL, [BX][SI]

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

(4) ADD WORD PTR [0524H], 2A59H

(5) ADD AL, 0B5H

3.3写出把首地址为BLOCK的字数组的第6个字送到DX寄存器的指令。要求使用以下几种寻址方式:

(1) 寄存器间接寻址

(2) 寄存器相对寻址

(3) 基址变址寻址

答:(1) MOV BX, OFFSET BLOCK

ADD BX, (6–1)*2

MOV DX, [BX]

(2) MOV BX, OFFSET BLOCK 改为:MOV BX, (6-1)*2

MOV DX, [BX+(6–1)*2] 也可MOV DX, BLOCK[BX]

(3) MOV BX, OFFSET BLOCK

MOV SI, (6–1)*2

MOV DX, [BX][SI]

3.4 现有(DS)=2000H ,(BX)=0100H ,(SI)=0002H ,(20100H)=12H ,(20101H)=34H ,(20102H)=56H ,

(20103H)=78H ,(21200H)=2AH ,(21201H)=4CH ,(21202H)=B7H ,(21203H)=65H ,试说明下列各条指令执行完后AX 寄存器的内容。 (1) MOV AX, 1200H (2) MOV AX, BX

(3) MOV AX, [1200H]

(4) MOV AX, [BX]

(5) MOV AX, 1100[BX]

(6) MOV AX, [BX][SI] (7) MOV AX, 1100[BX][SI] 答:(1) (AX)=1200H (2) (AX)=0100H (3) (AX)=4C2AH (4) (AX)=3412H

(5) (AX)=4C2AH (6) (AX)=7856H (7) (AX)=65B7H 3.5 给定(IP)=2BC0H ,(CS)=0200H ,位移量D=5119H ,(BX)=1200H ,(DS)=212AH ,(224A0H)=0600H ,

(275B9H)=098AH ,试为以下的转移指令找出转移的偏移地址。 (1) 段内直接寻址

(2) 使用BX 及寄存器间接寻址方式的段内间接寻址 (3) 使用BX 及寄存器相对寻址方式的段内间接寻址 答:(1) JMP NEAR PTR 5119H ;(IP)=5119H+((IP)+03H)=7CDCH ,物理地址PA=09CDCH

(IP)+03H 是JMP NEAR PTR 5119H 指令的下一条指令的首地址。

(2) JMP WORD PTR [BX] ;(IP)=((DS)*10H+(BX))=0600H ,PA=02600H (3) JMP D[BX] ;(IP)=((DS)*10H+(BX)+D)=098AH ,PA=0298AH 3.6 设当前数据段寄存器的内容为1B00H ,在数据段的偏移地址2000H 单元内,含有一个内容为0FF10H 和8000H 的指针,它们是一个16位变量的偏移地址和段地址,试写出把该变量装入AX 的指令序列,并画图表示出来。

答:MOV BX, [2000H] ;图示如上所示。

MOV AX, [2000H+2]

MOV ES, AX

MOV AX, ES:[BX] 3.7 在0624H 单元内有一条二字节JMP SHORT OBJ 指令,如其中位移量为(1) 27H ,(2) 6BH ,(3) 0C6H ,

试问转向地址OBJ 的值是多少? 答:(1) OBJ=0624H+02H+27H=064DH

(2) OBJ=0624H+02H+6BH=0691H (3) OBJ=0624H+02H+0C6H=05ECH ;C6H 对应的负数为-3AH (向上转移,负位移量) 3.8 假定(DS)=2000H ,(ES)=2100H ,(SS)=1500H ,(SI)=00A0H ,(BX)=0100H ,(BP)=0010H ,数据段中变量名VAL 的偏移地址为0050H ,试指出下列源操作数字段的寻址方式是什么?其物理地址值是多少? (1) MOV AX, 0ABH (2) MOV AX, BX (3) MOV AX, [100H] (4) MOV AX, VAL (5) MOV AX, [BX] (6) MOV AX, ES:[BX] (7) MOV AX, [BP] (8) MOV AX, [SI] (9) MOV AX, [BX+10] (10) MOV AX, VAL[BX] (11) MOV AX, [BX][SI] (12) MOV AX, VAL[BX][SI] 答:(1) 立即方式; 操作数在本条指令中

(2) 寄存器寻址方式; 操作数为 (BX)=0100H (3) 直接寻址方式; PA=20100H (4) 直接寻址方式; PA=20050H (5) BX 寄存器间接寻址方式; PA=20100H (6) 附加段BX 寄存器间接寻址方式; PA=21100H (7) BP 寄存器间接寻址方式; PA=15010H (8) SI 寄存器间接寻址方式; PA=200A0H

FFH 00H 80H 3.6题的作图表示

10H 1B00:2000H 1B00:2001H 1B00:2002H 1B00:2003H

8000:FF10H

8000:FF11H ?→(AL)

?→(AH) MOV BX, 2000H LES BX, [BX] MOV AX, ES?:[BX]

(9) BX 寄存器相对寻址方式; PA=20110H (10) BX 寄存器相对寻址方式; PA=20150H (11) BX 和SI 寄存器基址变址寻址方式; PA=201A0H (12) BX 和SI 寄存器相对基址变址寻址方式; PA=201F0H

3.9 在ARRAY 数组中依次存储了七个字数据,紧接着是名为ZERO 的字单元,表示如下:

ARRAY DW 23, 36, 2, 100, 32000, 54, 0 ZERO D W ?

(1) 如果BX 包含数组ARRAY 的初始地址,请编写指令将数据0传送给ZERO 单元。 (2) 如果BX 包含数据0在数组中的位移量,请编写指令将数据0传送给ZERO 单元。 答:(1) MOV AX, [BX+(7-1)*2]

MOV [BX+(7)*2], AX (2) MOV AX, ARRAY [BX]

MOV ARRAY [BX+2], AX

3.10 如TABLE 为数据段中0032单元的符号名,其中存放的内容为1234H ,试问以下两条指令有什么区别?

指令执行完后AX 寄存器的内容是什么? MOV AX, TABLE LEA AX, TABLE 答:MOV AX, TABLE 是将TABLE 单元的内容送到AX ,(AX)=1234H

LEA AX,TABLE 是将TABLE 单元的有效地址送到AX ,(AX)=0032H

3.11 执行下列指令后AX 寄存器中的内容是什么? TABLE DW 10, 20, 30, 40, 50 ;000AH, 0014H, 001EH, 0028H, 0032H ENTRY DW 3

MOV BX, OFFSET TABLE

ADD BX, ENTRY

MOV AX, [BX]

答:(AX)=1E00H (TABLE 的存储方式如右图所示)

3.12 下列ASCII 码串(包括空格符)依次存储在起始地址为CSTRING 的字节单元中:

CSTRING DB ‘BASED ADDRESSING ’

请编写指令将字符串中的第1个和第7个字符传送给DX 寄存器。 答:MOV DH, CSTRING

MOV DL, CSTRING+7-1

3.13 已知堆栈段寄存器SS 的内容是0FFA0H ,堆栈指针寄存器SP 的内容是00B0H ,先执行两条把8057H 和

0F79H 分别进栈的PUSH 指令,再执行一条POP 指令。试画出堆栈区和SP 的内容变化过程示意图(标出存储单元的物理地址)。

答:堆栈区和SP 的内容变化过程示意图如下左图所示。

3.14 设(DS)=1B00H ,,有关存储单元的内容如上右图所示。请写出两条指令把字变量X 装入AX

寄存器。 答:3.15 62A0H 之和,并根据结果设置标志位SF 、ZF 、CF 和OF 的值。 (1) 1234H (3) CFA0H (4) 9D60H 答:(1) 和为74D4H ;SF=0,ZF=0,CF=0,OF=0

(2) 和为A5C1H ;SF=1,ZF=0,CF=0,OF=1 (3) 和为3240H ;SF=0,ZF=0,CF=1,OF=0 (4) 和为0000H ;SF=0,ZF=1,CF=1,OF=0

3.16 求出以下各十六进制数与十六进制数4AE0H 的差值,并根据结果设置标志位SF 、ZF 、CF 和OF 的值。

(1) 1234H (2) 5D90H (3) 9090H (4) EA04H 答:(1) 差为C754H ;SF=1,ZF=0,CF=1,OF=0

(2) 差为12B0H ;SF=0,ZF=0,CF=0,OF=0 (3) 差为45B0H ;SF=0,ZF=0,CF=0,OF=1

0AH 00H 14H 00H

1EH

00H

28H 00H

32H

00H TABLE TABLE+3 3.11题的TABLE 存储方式 3.13 (SP)←(SP)-2 (SP)←(SP)-2 出栈时(SP)←(SP)+2 8000H

1B00:2000 3.14题的存储区情况 2B00H X

1B00:2002 2B00:8000

(4) 差为9F24H;SF=1,ZF=0,CF=0,OF=0

3.17写出执行以下计算的指令序列,其中X、Y、Z、R、W均为存放16位带符号数单元的地址。

(1) Z←W+(Z-X) (2) Z←W-(X+6)-(R+9)

(3) Z←(W*X)/(Y+6),R←余数(4) Z←((W-X)/5*Y)*2

答:(1) MOV AX, Z ;以下程序都未考虑带符号数的溢出

SUB AX, X

ADD AX, W

MOV Z, AX

(2) MOV BX, X

ADD BX, 6

MOV CX, R

ADD CR, 9

MOV AX, W

SUB AX, BX

SUB AX, CX

MOV Z, AX

(3) ADD Y, 6

MOV AX, W

IMUL X

IDIV Y

MOV Z, AX

MOV R, DX

(4) MOV AX, W

SUB AX, X

CWD

MOV BX, 5

IDIV BX

IMUL Y

SHL AX, 1 ;((DX),(AX))*2

RCL DX, 1

3.18已知程序段如下:

MOV AX, 1234H ;(AX)=1234H,标志位不变

MOV CL, 4 ;(AX)和标志位都不变

ROL AX, CL ;(AX)=2341H,CF=1,SF和ZF不变

DEC AX ;(AX)=2340H,CF=1不变,SF=0,ZF=0

MOV CX, 4 ;(AX)和标志位都不变

MUL CX ;(AX)=8D00H,CF=OF=0,其它标志无定义

INT 20H

试问:

(1) 每条指令执行完后,AX寄存器的内容是什么?

(2) 每条指令执行完后,进位、符号和零标志的值是什么?

(3) 程序结束时,AX和DX的内容是什么?

答:(1) 见注释;

(2) 见注释;

(3) (AX)=8D00H,(DX)=0

3.19下列程序段中的每条指令执行完后,AX寄存器及CF、SF、ZF和OF的内容是什么?

MOV AX, 0 ;(AX)=0, 标志位不变

DEC AX ;(AX)=0FFFFH, CF不变,SF=1,ZF=0,OF=0

ADD AX, 7FFFH ;(AX)=7FFEH, CF=1,SF=0,ZF=0,OF=0

ADD AX, 2 ;(AX)=8000H, CF=0,SF=1,ZF=0,OF=1

NOT AX ;(AX)=7FFFH, 标志位不变

SUB AX, 0FFFFH ;(AX)=8000H, CF=1,SF=1,ZF=0,OF=1

ADD AX, 8000H ;(AX)=0,CF=1,SF=0,ZF=1,OF=1

SUB AX, 1 ;(AX)=0FFFFH, CF=1,SF=1,ZF=0,OF=0

AND AX, 58D1H ;(AX)=58D1H, CF=0,SF=0,ZF=0,OF=0

SAL AX, 1 ;(AX)=0B1A2H, CF=0,SF=1,ZF=0,OF=1

SAR AX, 1 ;(AX)=0D8D1H, CF=0,SF=1,ZF=0,OF=0

NEG AX ;(AX)= 272FH, CF=1,SF=0,ZF=0,OF=0

ROR AX, 1 ;(AX)= 9397H, CF=1,SF和ZF不变,OF=1

答:见注释。

3.20变量DATAX和变量DATAY的定义如下:

DATAX DW 0148H

DW 2316H

DATAY DW 0237H

DW 4052H

请按下列要求写出指令序列:

(1) DATAX和DATAY两个字数据相加,和存放在DATAY中。

(2) DATAX和DATAY两个双字数据相加,和存放在从DATAY开始的双字单元中。

(3) 解释下列指令的作用:

STC

MOV BX, DATAX

ADC BX, DATAY

(4) DATAX和DATAY两个字数据相乘(用MUL)。

(5) DATAX和DATAY两个双字数据相乘(用MUL)。

(6) DATAX除以23(用DIV)。

(7) DATAX双字除以字DATAY (用DIV)。

答:(1) MOV AX, DATAX

ADD DATAY, AX

MOV AX, DATAX+2

ADD DATAY+2, AX

(2) MOV AX, DATAX

ADD DATAY, AX

MOV AX, DATAX+2

ADC DATAY+2, AX

MOV DATAY+4, 0 ;用于存放进位位

ADC DATAY+4, 0

(3) DATAX和DATAY两个字数据之和加1,结果存入BX寄存器。

(4) RESULT1 DW 0

DW 0

RESULT2 DW 0

DW 0

MOV AX, DATAX

MUL DATAY

MOV RESULT1 , AX

MOV RESULT1+2, DX

MOV AX, DATAX+2

MUL DATAY+2

MOV RESULT2 , AX

MOV RESULT2+2, DX

(5) AA DW 0

BB DW 0

CC DW 0

DD DW 0

MOV AX, DATAX

MUL DATAY

MOV AA , AX

MOV BB, DX

MOV AX, DATAX

MUL DATAY+2

ADD BB, AX

ADC CC, DX

MOV AX, DATAX+2

MUL DATAY

ADD BB, AX

ADC CC, DX

ADC DD, 0

MOV AX, DATAX+2

MUL DATAY+2

ADD CC, AX

ADC DD, DX

(6) MOV AX, DATAX

MOV BL, 23

DIV BL

(7) MOV DX, DATAX+2

MOV AX, DATAX

DIV DATAY

3.21写出对存放在DX和AX中的双字长数求补的指令序列。

答:NEG DX 也可为:NOT DX

NEG AX NOT AX

SBB DX, 0 ADD AX, 1

ADC DX, 0

3.22试编写一程序求出双字长数的绝对值。双字长数在A和A+2单元中,结果存放在B和B+2单元中。

答:程序段如下:

MOV AX, A

MOV DX, A+2

CMP DX, 0

JNS ZHENSHU ;不是负数则转走

NEG DX

NEG AX

SBB DX, 0

ZHENSHU: MOV B, AX

MOV B+2, DX

INT 20H

3.23假设(BX)=0E3H,变量VALUE中存放的内容为79H,确定下列各条指令单独执行后的结果。

(1) XOR BX, VALUE ;(BX)=9AH,CF、OF都为0,AF无定义,SF=1,ZF=0,PF=1

(2) AND BX, VALUE ;(BX)=61H,CF、OF都为0,AF无定义,SF=0,ZF=0,PF=0

(3) OR BX, VALUE ;(BX)=0FBH,CF、OF都为0,AF无定义,SF=1,ZF=0,PF=0

(4) XOR BX, 0FFH ;(BX)=1CH,CF、OF都为0,AF无定义,SF=0,ZF=0,PF=0

(5) AND BX, 0 ;(BX)=00H,CF、OF都为0,AF无定义,SF=0,ZF=1,PF=1

(6) TEST BX, 01H ;(BX)=0E3H,CF、OF都为0,AF无定义,SF=1,ZF=0,PF=0

答:见注释。

3.24试写出执行下列指令序列后BX寄存器的内容。执行前(BX)=6D16H。

MOV CL, 7

SHR BX, CL

答:(BX)=00DAH。

3.25试用移位指令把十进制数+53和-49分别乘以2。它们应该用什么指令?得到的结果是什么?如果要除

以2呢?

答:MOV AL, 53

SAL AL, 1 ;(AL)=(+53*2)=6AH

MOV AL, -49

SAL AL, 1 ;(AL)=(-49*2)=9EH

MOV AL, 53

SAR AL, 1 ;(AL)=(53/2)= 1AH

MOV AL, -49

SAR AL, 1 ;(AL)=(-49/2)=0E7H

3.26试分析下面的程序段完成什么功能?

MOV CL, 04

SHL DX, CL

MOV BL, AH

SHL AX, CL

SHR BL, CL

OR DL, BL

答:本程序段将 ((DX),(AX)) 的双字同时左移4位,即将此双字乘以10H (16)。

3.27假定(DX)=0B9H,(CL)=3,(CF)=1,确定下列各条指令单独执行后DX中的值。

(1) SHR DX, 1 ;(DX)=05CH

(2) SAR DX, CL ;(DX)=17H

(3) SHL DX, CL ;(DX)=5C8H

(4) SHL DL, 1 ;(DX)=72H

(5) ROR DX, CL ;(DX)=2017H

(6) ROL DL, CL ;(DX)=0CDH

(7) SAL DH, 1 ;(DX)=0B9H

(8) RCL DX, CL ;(DX)=2CCH

(4) RCR DL, 1 ;(DX)=0DCH

答:见注释。

3.28下列程序段执行完后,BX寄存器的内容是什么?

MOV CL, 3

MOV BX, 0B7H

ROL BX,1

ROR BX, CL

答:(BX)=0C02DH。

3.29假设数据段定义如下:

CONAME DB ‘SPACE EXPLORERS INC.’

PRLINE DB 20 DUP (‘’)

用串指令编写程序段分别完成以下功能:

(1) 从左到右把CONAME中的字符串传送到PRLINE。

(2) 从右到左把CONAME中的字符串传送到PRLINE。

(3) 把CONAME中的第3和第4个字节装入AX。

(4) 把AX寄存器的内容存入从PRLINE+5开始的字节中。

(5) 检查CONAME字符串中有无空格字符,如有则把第一个空格字符的地址传送给BX寄存器。

答:(1) MOV CX, 20

CLD

MOV SI, SEG CONAME

MOV DS, SI

MOV ES, SI

LEA SI, CONAME

LEA DI, PRLINE

REP MOVSB

(2) MOV CX, 20

STD

MOV SI, SEG CONAME

MOV DS, SI

MOV ES, SI

LEA SI, CONAME

ADD SI, 20-1

LEA DI, PRLINE

ADD DI, 20-1

REP MOVSB

(3) MOV AX, WORD PTR CONAME+3-1

(4) MOV WORD PTR PRLINE +5, AX

(5) MOV AL, ‘’;空格的ASCII码送AL寄存器

CLD

MOV DI, SEG CONAME

MOV ES, DI

LEA DI, CONAME

REPNE SCASB

JNE NEXT

DEC DI

MOV BX, DI

NEXT: ┇

3.30编写程序段,把字符串STRING中的‘&’字符用空格符代替。

STRING DB ‘The date is FEB&03’

答:程序段如下:

MOV CX, 18

MOV AL, ‘&’

CLD

MOV DI, SEG STRING

MOV ES, DI

LEA DI, STRING

REPNE SCASB

JNE NEXT

DEC DI

MOV ES:BYTE PTR [DI], ‘’;送空格符

NEXT: ┇

3.31假设数据段中数据定义如下:

STUDENT_NAME DB 30 DUP (?)

STUDENT_ADDR DB 9 DUP (?)

PRINT_LINE DB 132 D UP (?)

分别编写下列程序段:

(1) 用空格符清除PRINT_LINE域。

(2) 在STUDENT_ADDR中查找第一个‘-’。

(3) 在STUDENT_ADDR中查找最后一个‘-’。

(4) 如果STUDENT_NAME域中全是空格符时,填入‘*’。

(5) 把STUDENT_NAME移到PRINT_LINE的前30个字节中,把STUDENT_ ADDR移到PRINT_LINE的后9

个字节中。

答:公共的程序段如下:

MOV DI, DS

MOV ES, DI

(1) MOV CX, 132

MOV AL., ‘’;空格的ASCII码送AL寄存器

CLD

LEA DI, PRINT_LINE

REP STOSB

(2) MOV CX, 9

MOV AL., ‘-’

CLD

LEA DI, STUDENT_ ADDR

REPNE SCASB

JNE NO_DASH

DEC DI

NO_DASH: ┇

(3) MOV CX, 9

MOV AL., ‘-’

STD

LEA DI, STUDENT_ ADDR

ADD DI, 9-1

REPNE SCASB

JNE NO_DASH

INC DI

NO_DASH: ┇

(4) MOV CX, 30

MOV AL, ‘’;空格的ASCII码送AL寄存器

CLD

LEA DI, STUDENT_NAME

REPE SCASB

JNE NEXT

MOV CX, 30

MOV AL, ‘*’;“*”的ASCII码送AL寄存器

LEA DI, STUDENT_NAME

REP STOSB

NEXT: ┇

(5) MOV CX, 30

CLD

LEA SI, STUDENT_NAME

LEA DI, PRINT_LINE

REP MOVSB

MOV CX, 9

STD

LEA SI, STUDENT_ADDR+9-1

LEA DI, PRINT_LINE+132-1

REP MOVSB

3.32编写一程序段:比较两个5字节的字符串OLDS和NEWS,如果OLDS字符串不同于NEWS字符串则执行

NEW_LESS;否则顺序执行程序。

答:程序段如下:

MOV CX, 5

CLD

MOV DI, SEG OLDS

MOV DS, DI

MOV ES, DI

LEA SI, OLDS

LEA DI, NEWS

REPE C MPSB

JNE NEW_LESS

NEW_LESS: ┇

3.33假定AX和BX中的内容为带符号数,CX和DX中的内容为无符号数,请用比较指令和条件转移指令实现

以下判断:

(1) 若DX的内容超过CX的内容,则转去执行EXCEED。

(2) 若BX的内容大于AX的内容,则转去执行EXCEED。

(3) 若CX的内容等于0,则转去执行ZERO。

(4)BX与AX的内容相比较是否产生溢出?若溢出则转OVERFLOW。

(5) 若BX的内容小于等于AX的内容,则转EQ_SMA。

(6) 若DX的内容低于等于CX的内容,则转EQ_SMA。

答:(1) CMP DX, CX

JA EXCEED

(2) CMP BX, AX

JG EXCEED

(3) JCXZ ZERO

(4) CMP BX, AX

JO OVERFLOW

(5) CMP BX, AX

JLE EQ_SMA

(6) CMP DX, CX

JBE EQ_SMA

3.34试分析下列程序段:

ADD AX, BX

JNO L1

JNC L2

SUB AX, BX

JNC L3

JNO L4

JMP SHORT L5

如果AX和BX的内容给定如下:

AX BX

(1) 147BH 80DCH

(2) B568H 42C8H

(3) 42C8H 608DH

(4) D023H 9FD0H

(5) 94B7H B568H

问该程序分别在上面5种情况下执行后,程序转向哪里?

答:(1) 转向L1

(2) 转向L1

(3) 转向L2

(4) 转向L5 ;因为加法指令后AX中已经是6FF3H

(5) 转向L5 ;因为加法指令后AX中已经是4A14H

3.35指令CMP AX, BX后面跟着一条格式为J… L1的条件转移指令,其中…可以是B、NB、BE、NBE、L、

NL、LE、NLE中的任意一个。如果AX和BX的内容给定如下:

AX BX

(1) 1F52H 1F52H

(2) 88C9H 88C9H

(3) FF82H 007EH

(4) 58BAH 020EH

(5) FFC5H FF8BH

(6) 09A0H 1E97H

(7) 8AEAH FC29H

(8) D367H 32A6H

问以上8条转移指令中的哪几条将引起转移到L1?

答:(1) JNB、JBE、JNL、JLE

(2) JNB、JBE、JNL、JLE

(3) JNB、JNBE、JL、JLE

(4) JNB、JNBE、JNL、JNLE

(5) JNB、JNBE、JL、JLE

(6) JB、JBE、JL、JLE

(7) JB、JBE、JNL、JNLE

(8) JNB、JNBE、JL、JLE

3.36假设X和X+2单元的内容为双精度数p,Y和Y+2单元的内容为双精度数q,(X和Y为低位字)试说明

下列程序段做什么工作?

MOV DX, X+2

MOV AX, X

ADD AX, X

ADC DX, X+2

CMP DX, Y+2

JL L2

JG L1

CMP AX, Y

JBE L2

L1: MOV AX, 1

JMP SHORT EXIT

L2: MOV AX, 2

EXIT:INT 20H

答:此程序段判断p*2>q,则使(AX)=1后退出;p*2≤q,则使(AX)=2后退出。

3.37要求测试在STATUS中的一个字节,如果第1、3、5位均为1则转移到ROUTINE_1;如果此三位中有两

位为1则转移到ROUTINE_2;如果此三位中只有一位为1则转移到ROUTINE_3;如果此三位全为0则转移到ROUTINE_4。试画出流程图,并编制相应的程序段。

答:程序段如下:

AND AL, 00010101B ;只保留第1、3、5位

JZ ROUTINE_4 ;3位全为0转

JPE ROUTINE_2 ;两位为1转

CMP AL, 00010101B

JZ ROUTINE_1 ;3位全为1转

ROUTINE_3: ┇;仅一位为1执行

JMP EXIT

ROUTINE_1: ┇

JMP EXIT

ROUTINE_2: ┇

JMP EXIT

ROUTINE_4: ┇

EXIT: INT 20H

3.38在下列程序的括号中分别填入如下指令:

(1) LOOP L20

(2) LOOPE L20

(3) LOOPNE L20

试说明在三种情况下,当程序执行完后,AX、BX、

CX、DX四个寄存器的内容分别是什么?

3.44题的程序流程图

TITLE https://www.wendangku.net/doc/2719348025.html,

CODESG SEGMENT

ASSUME CS:CODESG, DS: CODSEG, SS: CODSEG

ORG 100H

BEGIN: MOV AX, 01

MOV BX, 02

MOV DX, 03

MOV CX, 04

L20:

INC AX

ADD BX, AX

SHR DX, 1

( )

RET

CODESG ENDS

END BEGIN

答:(1) (AX)=5H,(BX)=10H,(CX)=0H,(DX)=0H

(2) (AX)=2H,(BX)=4H,(CX)=3H,(DX)=1H

(3) (AX)=3H,(BX)=7H,(CX)=2H,(DX)=0H

3.39 考虑以下的调用序列:

(1) MAIN 调用NEAR 的SUBA 过程(返回的偏移地址为0400); (2) SUBA 调用NEAR 的SUBB 过程(返回的偏移地址为0A00);

(3) SUBB 调用FAR 的SUBC 过程(返回的段地址为B200,返回的偏移地址为0100); (4) 从SUBC 返回SUBB ;

(5) SUBB 调用NEAR 的SUBD 过程(返回的偏移地址为0C00); (6) 从SUBD 返回SUBB ; (7) 从SUBB 返回SUBA ; (8) 从SUBA 返回MAIN ;

(9) 从MAIN 调用SUBC(返回的段地址为1000,返回的偏移地址为0600); 请画出每次调用及返回时的堆栈状态。

答:每次调用及返回时的堆栈状态图如下所示:

3.40 假设(EAX)=00001000H ,(EBX)=00002000H ,(DS)=0010H ,试问下列指令访问内存的物理地址是什么? (1) MOV ECX ,[EAX+EBX] (2) MOV [EAX+2*EBX],CL (3) MOV DH ,[EBX+4*EAX+1000H] 答:(1) PA=(DS)*10H+EA=00100H+00001000H+00002000H=00003100H (2) PA=(DS)*10H+EA=00100H+00001000H+2*00002000H=00005100H (3) PA=(DS)*10H+EA=00100H+00002000H+4*00001000H+1000H=00007100H

3.41 假设(EAX)=9823F456H ,(ECX)=1F23491H ,(BX)=348CH ,(SI)=2000H ,(DI)=4044H 。在DS 段中从偏移

地址4044H 单元开始的4个字节单元中,依次存放的内容为92H ,6DH ,0A2H 和4CH ,试问下列各条指

令执行完后的目的地址及其中的内容是什么? (1) MOV [SI],EAX (2) MOV [BX],ECX

(3) MOV EBX ,[DI] 答:(1) 目的地址为DS:2000H ,内容依次为:56H ,0F4H ,23H 和98H (2) 目的地址为DS:348CH ,内容依次为:91H ,34H ,0F2H 和01H (3) 目的操作数为EBX 寄存器,(EBX)=4CA26D92H 3.42 说明下列指令的操作 (1) PUSH AX ;将(AX)压入堆栈 (2) POP ESI ;将堆栈中的双字弹出到ESI 寄存器中 (3) PUSH [BX] ;将((BX))对应存储单元中的字压入堆栈 (4) PUSHAD ;32位通用寄存器依次进栈 (5) POP DS ;将堆栈中的字弹出到DS 寄存器中 (6) PUSH 4 ;将立即数4以字的方式压入堆栈

答:见注释。

3.43 请给出下列各指令序列执行完后目的寄存器的内容。

(1) MOV EAX ,299FF94H

ADD EAX ,34FFFFH ;(EAX)= 2CEFF93H SUB EBX ,1500000 ;(EBX)= 3EB00000H AND EAX ,0F0F0F0FH ;(EAX)= 09090804H (4) MOV EDX ,9FE35DH

XOR EDX ,0F0F0F0H ;(EDX)= 6F13ADH 答:见注释。 3.44 请给出下列各指令序列执行完后目的寄存器的内容。

(1) MOV BX ,-12

MOVSX EBX ,BX ;(EBX)= 0FFFF FFF4H (2) MOV CL ,-8

MOVSX EDX ,CL ;(EDX)= 0FFFF FFF8H (3) MOV AH ,7

MOVZX ECX ,AH ;(ECX)= 0000 0007H (4) MOV AX ,99H

00 04 原SP 位置 新SP 位置 (1) MAIN 调 用SUBA 过程 00 0A 00 04 原SP 位置 新SP 位置

(2) SUBA 调 用SUBB 过程 00 01 00 B2 00 0A 00 原SP 位置 新SP 位置 (3) SUBB 调 用SUBC 过程 00 01 00 B2 00 0A 00

原SP 位置

新SP 位置 (4) 从SUBC 返回SUBB 00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (5) SUBB 调 用SUBD 过程 00 01 00 0C

00 0A 00 04 原SP 位置 新SP 位置 (6) 从SUBD 返回SUBB 00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (7) 从SUBB 返回SUBA

00 01 00 0C 00 0A 00 04 原SP 位置 新SP 位置 (8) 从SUBA 返回MAIN

00 01 00 0C 00 06 00 10 原SP 位置 新SP 位置 (9) 从MAIN

调用SUBC

MOVZX EBX,AX ;(EBX)= 0000 0099H

答:见注释。

3.45请给出下列指令序列执行完后EAX和EBX的内容。

MOV ECX,307 F455H

BSF EAX,ECX ;(EAX)= 0D

BSR EBX,ECX ;(EBX)= 25D

答:见注释。

3.46请给出下列指令序列执行完后AX和DX的内容。

MOV BX,98H

BSF AX,BX ;(AX)= 3D

BSR DX,BX ;(DX)= 7D

答:见注释。

3.47请编写一程序段,要求把ECX、EDX和ESI的内容相加,其和存入EDI寄存器中(不考虑溢出)。

答:MOV EDI,0 也可为:MOV EDI,ECX

ADD EDI,ECX ADD EDI,EDX

ADD EDI,EDX ADD EDI,ESI

ADD EDI,ESI

3.48请说明IMUL BX,DX,100H指令的操作。

答:(BX)←(DX)*100H

3.49试编写一程序段,要求把BL中的数除以CL中的数,并把其商乘以2,最后的结果存入DX寄存器中。

答:MOV AL,BL

MOV AH,0 ;假定为无符号数,否则用CBW指令即可

DIV CL

MOV AH,0

SHL AX,1

MOV DX,AX

3.50请说明JMP DI和JMP [DI]指令的区别。

答:JMP DI是转移到以(DI)内容为偏移地址的单元去执行指令;JMP [DI]是转移到以(DI)间接寻址的内存单元内容为偏移地址的单元去执行指令。

3.51试编写一程序段,要求在长度为100H字节的数组中,找出大于42H的无符号数的个数并存入字节单元

UP中;找出小于42H的无符号数的个数并存入字节单元DOWN中。

答:JMP BEGIN

UP DB 0

DOWN D B 0

TABLE DB 100H DUP (?) ;数组

BEGIN:

MOV CX,100H

MOV BX,-1

MOV SI,0

MOV DI,0

L1:INC BX

CMP TABLE[BX],42H

JA L2

JB L3

JMP L4

L2:INC SI

JMP L4

L3:INC DI

L4:LOOP L1

MOV UP,SI

MOV DOWN,DI

3.52请用图表示ENTER 16,0所生成的堆栈帧的情况。

002EH

002FH

0030H

0031H

0032H

0033H

0034H

0035H

0036H

0037H

0038H

0039H

003AH

003BH

003CH

003DH

帧原

答:答案见右图。

第四章. 习题

4.1指出下列指令的错误:

(1) MOV AH, BX ;寄存器类型不匹配

(2) MOV [BX], [SI] ;不能都是存储器操作数

(3) MOV AX, [SI][DI] ;[SI]和[DI]不能一起使用

(4) MOV MYDAT [BX][SI], ES:AX ;AX寄存器不能使用段超越

(5) MOV BYTE PTR [BX], 1000 ;1000超过了一个字节的范围

(6) MOV BX, OFFSET MYDAT [SI] ;MYDAT [SI]已经是偏移地址,不能再使用OFFSET

(7) MOV CS, AX ;CS不能用作目的寄存器

(8) MOV ECX, AX ;两个操作数的数据类型不同

答:见注释。

4.2下面哪些指令是非法的?(假设OP1,OP2是已经用DB定义的变量)

(1) CMP 15, BX ;错,立即数不能作为目的操作数

(2) CMP OP1, 25

(3) CMP OP1, OP2 ;错,不能都是存储器操作数

(4) CMP AX, OP1 ;错,类型不匹配,应为CMP ax, word ptr op1

答:见注释。

4.3假设下列指令中的所有标识符均为类型属性为字的变量,请指出下列哪些指令是非法的?它们的错误

是什么?

(1) MOV BP, AL ;错,寄存器类型不匹配

(2) MOV WORD_OP [BX+4*3][DI], SP

(3) MOV WORD_OP1, WORD_OP2 ;错,不能都是存储器操作数

(4) MOV AX, WORD_OP1[DX] ;错,DX不能用于存储器寻址

(5) MOV SAVE_WORD, DS

(6) MOV SP, SS:DATA_WORD [BX][SI]

(7) MOV [BX][SI], 2 ;错,[BX][SI]未指出数据类型

(8) MOV AX, WORD_OP1+WORD_OP2

(9) MOV AX, WORD_OP1-WORD_OP2+100

(10)MOV WORD_OP1, WORD_OP1-WORD_OP2

答:见注释。

4.4假设VAR1和VAR2为字变量,LAB为标号,试指出下列指令的错误之处:

(1) ADD VAR1, VAR2 ;不能都是存储器操作数

(2) SUB AL, VAR1 ;数据类型不匹配

(3) JMP LAB [SI] ;LAB是标号而不是变量名,后面不能加[SI]

(4) JNZ VAR1 ;VAR1是变量而不是标号

(5) JMP NEAR LAB ;应使用NEAR PTR

答:见注释。

4.5画图说明下列语句所分配的存储空间及初始化的数据值。

(1) BYTE_VAR DB ‘BYTE’,12,-12H,3 DUP(0,?,2 DUP(1,2),?)

(2) WORD_VAR DW 5 DUP(0,1,2),?,-5,‘BY’,‘TE’,256H

答:答案如下图所示。

4.6试列出各种方法,使汇编程序把5150H存入一个存储器字中(如:DW 5150H)。

答:DW 5150H

DB 50H, 51H DB ‘PQ’DW ‘QP’ORG 5150H DW $

42H

59H

54H

45H

0DH

EEH

00H

-

01H

02H

01H

BYTE_V AR 00H

00H

01H

00H

02H

00H

-

-

WORD_V AR

将上面

内容再

重复4次

4.7请设置一个数据段DATASG,其中定义以下字符变量或数据变量。

(1) FLD1B为字符串变量:‘personal computer’;

(2) FLD2B为十进制数字节变量:32;

(3) FLD3B为十六进制数字节变量:20;

(4) FLD4B为二进制数字节变量:01011001;

(5) FLD5B为数字的ASCII字符字节变量:32654;

(6) FLD6B为10个零的字节变量;

(7) FLD7B为零件名(ASCII码)及其数量(十进制数)的表格:

PART1 20

PART2 50

PART3 14

(8) FLD1W为十六进制数字变量:FFF0;

(9) FLD2W为二进制数的字变量:01011001;

(10) FLD3W为(7)零件表的地址变量;

(11) FLD4W为包括5个十进制数的字变量:5,6,7,8,9;

(12) FLD5W为5个零的字变量;

(13) FLD6W为本段中字数据变量和字节数据变量之间的地址差。

答:DATASG SEGMENT

FLD1B DB ‘personal computer’

FLD2B DB 32

FLD3B DB 20H

FLD4B DB 01011001B

FLD5B DB ‘32654’

FLD6B DB 10 DUP (0)

FLD7B DB ‘PART1’, 20

DB ‘PART2’, 50

DB ‘PART3’, 14

FLD1W DW 0FFF0H

FLD2W DW 01011001B

FLD3W DW FLD7B

FLD4W DW 5, 6, 7, 8, 9

FLD5W DW 5 DUP (0)

FLD6W DW FLD1W-FLD1B

DATASG ENDS

4.8假设程序中的数据定义如下:

PARTNO DW ?

PNAME DB 16 DUP (?)

COUNT DD ?

PLENTH EQU $-PARTNO

问PLENTH的值为多少?它表示什么意义?

答:PLENTH=22=16H,它表示变量PARTNO、PNAME、COUNT总共占用的存储单元数(字节数)。

4.9有符号定义语句如下:

BUFF DB 1, 2, 3, ‘123’

EBUFF DB 0

L EQU EBUFF - BUFF

问L的值是多少?

答:L=6。

4.10假设程序中的数据定义如下:

LNAME DB 30 DUP (?)

ADDRESS DB 30 DUP (?)

CITY DB 15 DUP (?)

CODE_LIST D B 1, 7, 8, 3, 2

(1) 用一条MOV指令将LNAME的偏移地址放入AX。

(2) 用一条指令将CODE_LIST的头两个字节的内容放入SI。

(3) 用一条伪操作使CODE_LENGTH的值等于CODE_LIST域的实际长度。

答:(1) MOV AX, OFFSET LNAME

(2) MOV SI, WORD PTR CODE_LIST

(3) CODE_LENGTH EQU $ - CODE_LIST ;此语句必须放在CODE_LIST语句之后

4.11试写出一个完整的数据段DATA_SEG,它把整数5赋予一个字节,并把整数-1,0,2,5和4放在10字

数组DATA_LIST的头5个单元中。然后,写出完整的代码段,其功能为:把DATA_LIST中头5个数中的最大值和最小值分别存入MAX和MIN单元中。

答:DATA_SEG SEGMENT

NUM DB 5

DATA_LIST DW -1, 0, 2, 5, 4, 5 DUP (?)

MAX DW ?

MIN DW ?

DATA_SEG ENDS

;----------------------------------------------------------------

CODE_SEG SEGMENT

MAIN PROC F AR

ASSUME CS: CODE_SEG, DS: DATA_SEG

START: PUSH D S ;设置返回DOS

SUB AX, AX

PUSH AX

MOV AX, DATA_SEG ;给DS赋值

MOV DS, AX

MOV CX, 4 ;程序段开始

LEA BX, DATA_LIST

MOV AX, [BX]

MOV MAX, AX

MOV MIN, AX

ROUT1: ADD BX, 2

MOV AX, [BX]

CMP AX, MAX

JNGE ROUT2

MOV MAX, AX

ROUT2: CMP AX, MIN

JNLE ROUT3

MOV MIN, AX

ROUT3: LOOP R OUT1 ;程序段结束

RET

MAIN ENDP

CODE_SEG ENDS

;----------------------------------------------------------------

END START

4.12给出等值语句如下:

ALPHA EQU 100

BETA EQU 25

GAMMA EQU 2

下列表达式的值是多少?

(1) ALPHA * 100 + BETA ;=2729H

(2) ALPHA MOD GAMMA + BETA ;=19H

(3) (ALPHA +2) * BETA – 2 ;=9F4H

(4) (BETA / 3) MOD 5 ;=3H

(5) (ALPHA +3) * (BETA MOD GAMMA) ;=67H

(6) ALPHA GE GAMMA ;=0FFFFH

(7) BETA AND 7 ;=01H

(8) GAMMA OR 3 ;=03H

答:见注释。

4.13对于下面的数据定义,三条MOV指令分别汇编成什么?(可用立即数方式表示)

TABLEA DW 10 DUP (?)

TABLEB DB 10 DUP (?)

TABLEC DB ‘1234’

MOV AX, LENGTH TABLEA ;汇编成MOV AX, 000AH

MOV BL, LENGTH TABLEB ;汇编成MOV BL, 000AH

MOV CL, LENGTH TABLEC ;汇编成MOV CL, 0001H

答:见注释。

4.14对于下面的数据定义,各条MOV指令单独执行后,有关寄存器的内容是什么?

FLDB DB ?

TABLEA DW 20 DUP (?)

TABLEB DB ‘ABCD’

(1) MOV AX, TYPE FLDB ;(AX)=0001H

(2) MOV AX, TYPE TABLEA ;(AX)=0002H

(3) MOV CX, LENGTH TABLEA ;(CX)=0014H

(4) MOV DX, SIZE TABLEA ;(DX)=0028H

(5) MOV CX, LENGTH TABLEB ;(CX)=0001H

答:见注释。

4.15指出下列伪操作表达方式的错误,并改正之。

(1) DATA_SEG SEG ;DATA_SEG SEGMENT(伪操作错)

(2) SEGMENT ‘CODE’;SEGNAME SEGMENT ‘CODE’(缺少段名字)

(3) MYDATA SEGMENT/DATA ;MYDATA SEGMENT

ENDS ;MYDATA ENDS(缺少段名字)

(4) MAIN_PROC PROC FAR ;删除END MAIN_PROC也可以

END MAIN_PROC ;MAIN_PROC ENDP ;上下两句交换位置

MAIN_PROC ENDP ;END MAIN_PROC 答:见注释。

4.16按下面的要求写出程序的框架

(1) 数据段的位置从0E000H开始,数据段中定义一个100字节的数组,其类型属性既是字又是字节;

(2) 堆栈段从小段开始,段组名为STACK;

(3) 代码段中指定段寄存器,指定主程序从1000H开始,给有关段寄存器赋值;

(4) 程序结束。

答:程序的框架如下:

DATA_SEG SEGMENT AT 0E000H

ARRAY_B L ABEL BYTE

ARRAY_W D W 50 DUP (?)

DATA_SEG ENDS ;以上定义数据段

;----------------------------------------------------------------

STACK_SEG SEGMENT PARA STACK ‘STACK’

DW 100H DUP (?)

TOS LABEL WORD

STACK_SEG ENDS ;以上定义堆栈段

;----------------------------------------------------------------

CODE_SEG SEGMENT

MAIN PROC F AR

ASSUME CS: CODE_SEG, DS: DATA_SEG, SS: STACK_SEG

ORG 1000H

START: MOV AX, STACK_SEG

MOV SS, AX ;给SS赋值

MOV SP, OFFSET TOS ;给SP赋值

PUSH DS ;设置返回DOS

SUB AX, AX

PUSH AX

MOV AX, DATA_SEG

MOV DS, AX ;给DS赋值

┇;程序段部分

RET

MAIN ENDP

CODE_SEG ENDS ;以上定义代码段

;----------------------------------------------------------------

END START

4.17写一个完整的程序放在代码段C_SEG中,要求把数据段D_SEG中的AUGEND和附加段E_SEG中的ADDEND

相加,并把结果存放在D_SEG 段中的SUM中。其中AUGEND、ADDEND和SUM均为双精度数,AUGEND赋值为99251,ADDEND赋值为 -15962。

答:程序如下:

D_SEG SEGMENT

AUGW LABEL WORD

AUGEND DD 99251

SUM DD ?

D_SEG ENDS ;以上定义数据段

;----------------------------------------------------------------

E_SEG SEGMENT

ADDW LABEL WORD

ADDEND DD -15962

E_SEG ENDS ;以上定义附加段

;----------------------------------------------------------------

C_SEG SEGMENT

MAIN PROC F AR

ASSUME CS: C_SEG, DS: D_SEG, ES: E_SEG

START: PUSH D S ;设置返回DOS

SUB AX, AX

PUSH AX

MOV AX, D_SEG

MOV DS, AX ;给DS赋值

MOV AX, E_SEG

MOV ES, AX ;给ES赋值

MOV AX, AUGW ;以下6条指令进行加法计算

MOV BX, AUGW+2

ADD AX, ES: ADDW

ADC BX, ES: ADDW+2 ;不考虑有符号数溢出

MOV WORD PTR SUM, AX

MOV WORD PTR [SUM+2], BX

RET

MAIN ENDP

C_SEG ENDS ;以上定义代码段

;----------------------------------------------------------------

END START

4.18请说明表示程序结束的伪操作和结束程序执行的语句之间的差别。它们在源程序中应如何表示?

答:表示程序结束的伪操作是指示汇编程序MASM结束汇编的标志,在源程序中用END表示;结束程序执行的语句是结束程序运行而返回操作系统的指令,在源程序中有多种表示方法,比如INT 20H 或MOV AX, 4C00H INT 21H以及RET等。

4.19试说明下述指令中哪些需要加上PTR操作符:

BVAL D B 10H,20H

新版汇编语言程序设计习题答案(钱晓捷主编)电子教案

新版汇编语言程序设计习题答案(钱晓捷主 编)

新版汇编语言程序设计习题答案(钱晓捷主编) 第一章汇编语言基础知识 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 (2)-127 (3)127 (4)-57 (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码,则代表哪个字符? 1.12、简述Intel 80x86系列微处理器在指令集方面的发展。 1.13、什么是DOS和ROM-BIOS? 1.14、简述PC机最低1MB主存空间的使用情况。 1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用。 1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义。

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

汇编语言程序设计习题答案 第一章. 习题 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.3习题与综合练习 1.解释和区别下列名词术语 (1)微处理器(MP):具有中央处理器功能的大规模集成电路器件 微型计算机(MC) 微型计算机系统(MCS) (2)硬件:硬件是计算机系统的躯体,由控制器,运算器,存储器,输入设备,输出设备5大部分组成。 软件:软件是计算机的头脑和灵魂,可分为系统软件和应用软件。 (3)字节:8位二进制是一个字节。 字:16位二进制构成一个字。 字长:计算机的运算部件能同时处理的二进制数据的位数。 (4)指令指针:存放BIU要取的下一条指令的偏移地址。 指令寄存器: 指令译码器: 状态寄存器: (5)存储单元: 存储内容: 存储地址: 存储容量: (6)RAM: ROM: 软件固化: 2.冯·诺依曼计算机结构的特点是什么? (1)采用二进制数的形式表示数据和指令。 (2)将指令和数据存放在存储器中。 (3) 计算机硬件由控制器,运算器,存储器,输入设备和输出设备5大部分组成。 3.件数计算机系统中复杂指令集和精简指令集的特点和用途。 复杂指令集(CISC):在微型计算机的体系结构组成结构上是以复杂指令为设计的计算机,在指令的运行过程中按指令的复杂程度来指挥计算机完成各条指令,由于各条指令复杂程度不同分配的时钟周期各不相同,执行指令所需时间就不相同。CISC体系的指令集由微程序来实现,即每一个操作由若干微操作的程序组合来实现。所以CISC可以使用微指令编程的方式实现多种和功能复杂的指令。 精简指令系统(RISC):不管计算机的指令如何复杂,在一个计算机时钟周期内完成,计算速度快,指令集简单。每一条指令直接有硬布线实现,即它的每条指令原则上有自己的一套逻辑时序电路直接实现,所以单条指令的实现所占用的硬件资源较多。因为该体系没有能采用增加单条指令的功能或高位的指令语义,也没有增加指令的条数,而是集中于它的精简指令集上。 4.CPU是计算机系统中的重要部件,试说明CPU的结构和功能。 微处理器是计算机中最关键的部件,由控制器,运算器,寄存器组和辅助部件组成。 控制器是硬件系统的指挥部,负责从存储器中取出指令,分析指令,确定指令类型并对指令进行译码,按时间先后顺序负责向其他各部件发出控制信号,保证各部件协调工作。运算器是用来进行算术运算和逻辑运算的元件。寄存器组用来存放计算所需的各种操作数,地址

汇编语言程序设计题目以及答案

一、单项选择题(每小题1分,共20分) 1、设DS=8225H,DI=3942H,指令NEG BYTE PTR[DI]操作数的物理地址是(A) A、85B92H B、86192H C、BB690H D、12169H 2、下列寄存器组中在段内寻址时可以提供偏移地址的寄存器组是(B) A、AX,BX,CX,DX B、BX,BP,SI,DI C、SP,IP,BP,DX D、CS,DS,ES,SS 3、循环指令LOOPNZ终止循环的条件是(B)。 A、CX=0,且ZF=0 B、CX=0,或ZF=1 C、CX10,且ZF=0 D、CX10,或ZF=1 4、对寄存器AX的内容乘以4的正确指令序列是(B)。 A、SHR AX,1 /SHR AX,1 B、SHL AX,1/ SHL,AX,1 C、ROL AX,1 /ROL AX,1 D、RCR AX,1/ RCR AX,1 5、执行INC指令除对SF、ZF有影响外,还要影响的标志位是(A)。 A、OF,AF,PF B、OF,AF,CF C、OF,PF,CF D、AF,PF,CF 6、设DH=10H,执行NEG DH指令后,正确的结果是(D)。 A、DH=10H CF=1 B、DH=0F0H CF=0 C、DH=10H CF=0 D、DH=0F0H CF=1 7、下列传送指令中有语法错误的是(A)。 A、MOV CS,AX B、MOV DS,AX C、MOV SS,AX D、MOV ES,AX 8、下面指令执行后,改变AL寄存器内容的指令是(D)。 A、TEST AL,02H B、OR AL,AL C、CMP AL,BL D、AND AL,BL 9、执行除法指令后,影响的标志位是(D)。 A、CF,OF

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

汇编语言程序设计习题及答案 汇编语言程序设计习题及答案 汇编语言是一种底层的计算机语言,它直接操作计算机的硬件资源。虽然在现 代计算机编程中,高级语言如C、Java等更为常见,但了解汇编语言的基本原 理和编程技巧对于理解计算机底层工作原理和进行性能优化非常重要。本文将 介绍一些汇编语言程序设计的习题及其答案,帮助读者巩固和提升汇编语言编 程能力。 一、基础习题 1. 编写一个汇编程序,将存储器中的某个字节的值加1,并将结果存回原位置。答案: ```assembly MOV AL, [地址] INC AL MOV [地址], AL ``` 2. 编写一个汇编程序,计算存储器中一个数组的和,并将结果存放在指定的寄 存器中。 答案: ```assembly MOV CX, 数组长度 MOV BX, 数组首地址 MOV AX, 0

LOOP_START: ADD AX, [BX] ADD BX, 2 LOOP LOOP_START ``` 二、进阶习题 1. 编写一个汇编程序,实现字符串的逆序输出。答案: ```assembly MOV SI, 字符串首地址 MOV DI, 字符串尾地址 MOV CX, 字符串长度 DEC CX REVERSE: MOV AL, [SI] MOV AH, [DI] MOV [DI], AL MOV [SI], AH INC SI DEC DI LOOP REVERSE ```

2. 编写一个汇编程序,实现两个16位无符号整数的相乘,并将结果存放在指定的寄存器中。 答案: ```assembly MOV AX, 第一个数 MOV BX, 第二个数 MUL BX ``` 三、挑战习题 1. 编写一个汇编程序,实现一个简单的计算器,支持加法、减法、乘法和除法运算。 答案: ```assembly READ_INPUT: ; 读取用户输入 ; ... PARSE_INPUT: ; 解析用户输入,获取操作数和运算符 ; ... CALCULATE: ; 根据运算符进行相应的计算 ; ...

汇编语言程序设计练习题及参考答案

一、单项选择题 从每小题的四个备选答案中,选出一个正确答案,并将正确答案的番号填人括号内。 1.用来存放下一条将要执行的指令地址的寄存器是 (B ) A.SP B.IP C.BP D.CS 2.要使串处理从低地址向高地址进行,应把标志位置为 (D ) A.IF=1 B.TF=0 C.DF=1 D.DF=0 3.使状态标志位CF清零的错误指令是 (C ) A.OR AX,AX B.SUB AX,AX C.MOV CF,0 D.CLC 4.设SP=1110H,执行PUSH AX指令后,SP的内容为 (B ) A.SP=1112H B.SP=110EH C.SP=1111H D.SP=110FH 5.汇编源程序出现语法错误的指令有 (D ) A.MOV [BX+SI],AL B. MOV AX,[BP+DI] C.MOV DS,AX D. MOV CS,AX 6.下列串操作指令中,必须同时指明源串和目的串地址的指令是 (D ) A.STOSW B.LODSW C.SCASW D.CMPSW 7.设BL中有一无符号数,实现把BL中的数乘以2,应选用的指令是 (B ) A.SHR BL,1 B.SHL BL,1 C.SAR BL,1 D.RCR BL,1 8.执行PUSH AX指令的正确步骤是 (A ) A.1.SP←SP-1,(SP)←AH B.1.(SP)←AH,SP←SP-1 2.SP←SP-1,(SP)←AL 2.(SP)←AL,SP←SP-1 C.1.SP←SP+1,(SP)←AH D.1.(SP)←AH,SP←SP+1 2.SP←SP+1,(SP)←AL 2.(SP)←AL,SP←SP+1 9.CF=1 时转移到目标地址的条件转移指令是 (B ) A.JNC B.JC C.JZ D.JS 10.在执行NEG指令时,对标志位CF有影响,其影响的规则是 ( C ) A.对正数求补时,CF=0 B.对负数求补时,CF=0 C.对非零数求补时,CF=1 D.对零求补时,CF=1 11.算术右移SAR和逻辑右移SHR两条指令执行后结果完全相同的情况是(A ) A.目的操作数最高位为0 B.目的操作数最高位为1 C.目的操作数为任意情况 D.无论什么情况都不可能相同 12.设AL=04H,BL=0F8H,执行IMUL BL指令后,结果是 ( D ) A.AX=0032H B.AX=00E0H C.AX=03E0H D.AX=0FFE0H 13.指令的操作数中,允许出现表达式,例如BUF1与BUF2均为变量名,下面指令中语法正确的是 (D ) A.MOV AX,BUFl*BUF2 B.MOV AX,BUF1/BUF2 C.MOV AX,BUF1+ES:BUF2

计算机组成原理与汇编语言程序设计课后习题及解答(详解)

计算机组成原理与汇编语言程序设计课后习题及解答 徐, 第1章习题一 1.什么是程序存储工作方式? 答:计算机的工作方式——存储程序工作方式。即事先编写程序,再由计算机把这些信息存储起来,然后连续地、快速地执行程序,从而完成各种运算过程。 2.采用数字化方法表示信息有哪些优点? 用数字化方法表示信息的优点: (1)抗干扰能力强, 可靠性高。 (2)依靠多位数字的组合,在表示数值时可获得很宽的表示范围以及很高的精度。 (3)数字化的信息可以存储、信息传送也比较容易实现。 (4)可表示的信息类型与范围及其广泛,几乎没有限制。 (5)能用逻辑代数等数字逻辑技术进行信息处理,这就形成了计算机硬件设计的基础。 3.如果有7×9点阵显示出字符A的图像,请用9个七位二进制代码表示A的点阵信息。 4.数字计算机的主要特点是什么? 1. (1)能在程序控制下自动连续地工作; (2|)运算速度快; (3)运算精度高; (4)具有很强的信息存储能力; (5)通用性强,应用领域及其广泛。 5.衡量计算机性能的基本指标有哪些? 答:衡量计算机性能的基本指标: (1)基本字长——参加一次运算的数的位数; (2)数据通路宽度——数据总线一次能并行传送的位数; (3)运算速度——可用①CPU的时钟频率与主频,②每秒平均执行指令数,③典型四则运算的时间来表示。 (4)主存储器容量——可用字节数或单元数(字数)×位数来表示。 (5)外存容量——常用字节数表示。 (6)配备的外围设备及其性能。 (7)系统软件配置。 7.系统软件一般包括哪些部分?列举你所熟悉的三种系统软件。 系统软件一般包括操作系统,编译程序、解释程序、各种软件平台等。例如WINDOWS98操作系统,C语言编译程序等,数据库管理系统。 8.对源程序的处理有哪两种基本方式? 对源程序的处理通常有两种处理方式:解释方式和编译方式。 第2章习题二 1.将二进制数(101010.01)2 转换为十进制数及BCD码。 解:(101010.01)2 = (42.25)10 = (01000010.00100101)BCD 2.将八进制数(37.2)8转换为十进制数及BCD码. 解:(37.2)8 = (31.25)10 =(00110001.00100101)BCD 3.将十六进制数(AC.E)转换为十进制数及BCD码. 解: (AC.E)16 =(172.875)10 = 0.1)BCD 4.将十进制数(7 5.34)10转换为8位二进制数及八进制数、十六进制数。

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

一、单项选择题(在每小题列出的四个备选项中只有一个是符合题目要求的,请将其代码填写在题后的括号内。) 1.为在一连续的存储单元中,依次存放数据41H,42H,43H,44H,45H,46H,可选用的数据定义语句是(D) A.DB 41,42,43,44,45,46 B.DW 4142H,4344H,4546H C.DW ‘AB’,‘CD’,‘EF’D.DW ‘BA’,‘DC’,‘FE’ 2.DA2 DB‘AB’,‘CD’ ┇ MOV AX,WORD PTR DA2+1 上述语句执行后AX中的值是(D) A.‘AD’B.‘BC’ C.‘DA’D.‘CB’ 3.下列数据定义语句中可实现留空20H个字节存储单元的是(D) A.DB 20 DUP(?) B.DW 20H DUP(?) C.DB 10H DUP(4 DUP(?)) D.DD 08H DUP(?) 4.如某存储器分段时,表示偏移地址是17位二进制代码,那么一个段最多的存储单元数是(D) A.32K字节B.32K字 C.64K字节D.64K字 5.下列寄存器中用来指示堆栈中任意数据区的偏移地址的是(B)A.BX B.BP C.SI D.DI 6.下列指令中有语法错误的是(C) A.PUSH AX B.PUSH [20H+SI+BX] C.POP CS D.PUSH CS 7.执行PUSH BP指令时,目的操作数的物理地址表达式是(D) A.16*SS+BP B.16*DS+BP C.16*CS+IP D.16*SS+SP 8.把BL中的数据输出到端口8CH中正确指令是(C) A.OUT 8CH,BL B.IN 8CH,BL C.MOV AL,BL D.MOV AL,BL OUT 8CH,AL IN 8CH,AL 9.结果为零的条件转移指令,其测试条件是(A) A.ZF=1 B.ZF=0 C.SF=l D.SF=0 10.下面程序段完成测试DA-BYTE字节单元中数是否为负数,若是则将全l送DH中,否则全0送DH中,那么程序段中方框里应填的语句是 MOV CH,0 MOV CH,0FFH ZERO:MOV DH,CH(C) A.JNZ ZERO B.JS ZERO

《汇编语言程序设计》必考试题及答案

《汇编语言程序设计》必考试题及答案 一、选择题 1. 汇编语言属于 ____。 A. 高级语言 B. 机器语言 C. 低级语言 D. 自然语言 答案:C. 低级语言 2. 在汇编语言中,寄存器eax主要用于 ____。 A. 存储返回值 B. 存储函数参数 C. 存储局部变量 D. 存储全局变量 答案:A. 存储返回值 3. 汇编语言中,jmp指令用于 ____。 A. 设置循环条件 B. 调用子程序

C. 跳转到指定地址 D. 返回主程序 答案:C. 跳转到指定地址 二、简答题 1. 请简述汇编语言与高级语言的区别。 汇编语言是一种低级语言,使用助记符来代表机器指令,每条汇编 指令对应一条机器指令。而高级语言更加抽象,采用更接近人类自然 语言的表达方式,通过编译器将高级语言编写的程序转换为机器语言。 2. 请列举汇编语言常用的寄存器及其作用。 汇编语言常用的寄存器包括: - eax:主要用于存储返回值。 - ebx、ecx、edx:通用寄存器,用于暂存计算结果。 - esi、edi:源操作数寄存器和目的操作数寄存器,用于存储数据传 输时的源地址和目的地址。 - ebp、esp:用于管理函数调用过程中的栈帧。 - eip:指令指针寄存器,存储下一条将要执行的机器指令的地址。 三、编程题

请编写汇编语言程序,实现从键盘输入两个数,并将其相加后输出的功能。 ```assembly section .data prompt db '请输入两个数,以空格分隔:', 0 result db '两数相加的结果为:%d', 0 section .bss num1 resb 4 num2 resb 4 section .text global _start _start: ; 输出提示信息 mov eax, 4 mov ebx, 1 mov ecx, prompt mov edx, 20 int 0x80 ; 输入第一个数

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

4.1分析执行下列指令序列后的结果:1)MOVAX,1234H MOVBX,00FFH ANDAX,BX 【答】(AX)=0034H 2)MOVAL,0101B ANDAL,000111B;(AL)=000101B ORAL,11000B;(AL)=110101B XORAL,0011B;(AL)=11010B NOTAL 【答】(AL)=00101B 3)MOVDL,05H MOVAX,0A00H MOVDS,AX MOVSI,0H MOVCX,0FH AGAIN: INCSI CMP[SI],DL LOOPNE AGAIN HLT

本程序实现了什么功能? 【答】在以0A001H开始的15个单元中查找05H。 4)MOVAX,DSEGADDR MOVDS, AX MOVES,AX MOVSI, OFFSET B1ADDR MOVDI,OFFSET B2ADDR MOVCX,N CLD REPMOVSB HLT 本程序实现了什么功能? 【答】将B1ADDR中N个字节数据传送到B2ADDR开始的15个存储单元。5)MOVAX, 0H MOVDS,AX MOVES, AX MOVAL,05H MOVDI,0A000H MOVCX,0FH CLD AGAIN:

SCASB LOOPNEAGAIN HLT 本程序实现了什么功能? 【答】从地址0A000H开始的15个单元中查找字节型数据05H,用条件循环LOOPNZ,控制数据05H的查找。 4.2阅读程序: 1).CLD LEADI,[0100H] MOVCX, 0080H XORAX, AX REPSTOSW 本程序实现了什么功能? 【答】将DS中起始地址为0100H的128个字节单元清零。 2).MOVAL, 08H SAL,01H;(AL)=000100H MOVBL, AL MOVCL ,02H SAL,CL;(AL)=01000H ADDAL,BL;(AL)=0100H 本程序实现了什么功能?

汇编语言程序设计题库练习题1--详细答案

汇编语言程序设计题库练习题1--详细答案 汇编语言程序设计练习题 一、单项选择题 1、与100.5不相等的数据是【 C 】 A. 64.8H B. 1100100.1B C. 64.5H D. 144.4O 2、指向程序代码段的段寄存器是【 A 】 A. CS B. DS C. SS D. FS 3、在内存字单元(20000)中存放数1324H,即(20000)=1324H,则从字节单元20001H 中取出一个字节为【 A 】A. 13H B. 24H C. 1324H D. 2413H 4、完成将累加器AL清零,并使进位标志CF清零,下面错误的指令是【 A 】 A. MOV AL,00H B. AND AL,00H C. XOR AL,AL D. SUB AL,AL 5、指令JMP BX转移的目标地址的偏移量为【 C 】 A. IP+BX的内容 B. IP+[BX] C. BX的内容 D. BX所指向的内存字单元的内容

6、DA1 DW 2A05H DA2 DB 07AH ┇ MOV AL,BYTE PTR DA1 SUB DA2,AL 上述指令执行后,DA2中的内容是【 C 】A. 7AH B. 02AH C. 075H D. 050H 7、某存储单元的物理地址是12345H,可以作为它的段地址有【 d 】 A. 2345H B. 12345H C. 12340H D. 1234H 8、设有数据定义X2 DW 10 DUP (0,1,2),定义了多少字节的缓冲【 C 】 A. 6 B. 30 C. 60 D. 40 9、有符号数AX除以2的指令是【 B 】 A. SHR AX,1 B. SAR AX,1 C. ROR AX,1 D. RCR AX,1 10、DEC BYTE PTR[BX]中的操作数的数据类型是【 C 】 A. 字 B. 双字 C. 字节 D. 四字

汇编语言程序设计答案

汇编语言程序设计答案2篇 汇编语言程序设计答案(一) 汇编语言是一种底层的计算机语言,通过程序设计来控制计算机 硬件的运行。它是计算机体系结构的基础,可以用来编写高效的程序,实现各种任务。下面是两个关于汇编语言程序设计的答案,帮助初学 者理解汇编语言的基本概念和编程技巧。 答案一: ```assembly mov ax, 5 mov bx, 6 add ax, bx ``` 这个程序的作用是将寄存器ax的值设置为5,寄存器bx的值设置为6,然后将ax和bx的值相加,结果保存在ax中。最后,ax的值为11。 答案二: ```assembly mov ax, 10 mov bx, 2 div bx ``` 这个程序的作用是将寄存器ax的值设置为10,寄存器bx的值设置为2,然后将ax和bx的值相除,商保存在ax中,余数保存在dx中。最后,ax的值为5,dx的值为0。 通过以上两个简单的答案,我们可以看到汇编语言的基本操作和 计算能力。编写汇编语言程序需要了解计算机的底层架构和指令集, 因为每种计算机体系结构都有不同的汇编语言。因此,学习汇编语言 需要掌握计算机组成原理和计算机体系结构的基本知识。 在编写汇编语言程序时,我们通常需要使用一些常见的指令,例

如mov(数据传送)、add(加法运算)、sub(减法运算)、mul(乘法运算)、div(除法运算)、jmp(跳转指令)等等。掌握这些常用指令和相应的语法规则是学习汇编语言的基础。 另外,汇编语言程序设计也需要学习如何使用寄存器和内存。寄存器是存储在CPU内部的非常快速的存储器,可以暂时存储数据和指令。CPU可以直接读取和写入寄存器中的数据。内存是存储在计算机主存储器中的大量数据和指令。CPU需要通过地址来访问内存中的数据和指令。 要编写高效的汇编语言程序,我们需要理解计算机的硬件原理和底层运行机制。了解汇编语言可以提供对程序的细粒度控制,对程序性能的优化有很大帮助。 总的来说,汇编语言程序设计是一项复杂而有趣的任务。掌握汇编语言可以让程序员对计算机的运行原理有更深入的理解,也能开发出更高效的程序。学习汇编语言需要耐心和熟练,但一旦掌握了它的技巧,将会有很多有趣的事情等待你去探索。 汇编语言程序设计答案(二) 汇编语言是一种底层的计算机语言,通过控制计算机硬件的运行来实现各种任务。在这里,我们将提供两个关于汇编语言程序设计的答案,帮助初学者理解汇编语言的基本概念和编程技巧。 答案一: ```assembly mov ax, 1 mov bx, 2 cmp ax, bx jg bigger jl smaller jmp end bigger: mov cx, ax jmp end

新版汇编语言程序设计习题答案(钱晓捷主编)

新版汇编语言程序设计习题答案(钱晓捷主编) 第一章汇编语言基础知识 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 (2)-127 (3)127 (4)-57 (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码,则代表哪个字符? 1.12、简述Intel 80x86系列微处理器在指令集方面的发展。 1.13、什么是DOS和ROM-BIOS? 1.14、简述PC机最低1MB主存空间的使用情况。 1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用。 1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义。

最新版汇编语言程序设计习题答案详解

新版汇编语言程序设计习题答案详解 第一章汇编语言基础知识 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 (2)-127 (3)127 (4)-57 (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码,则代表哪个字符? 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标志的差异。

汇编语言程序设计试题参考答案

汇编语言程序设计参考答案 A卷 一、单项选择题(本大题共8小题,每小题2分,共16分) 1.C 2.B 3.B 4.A 5.C 6.A 7.A 8.C 9.D 10.B 二、名词解释(本大题共5小题,每小题4分,共20分) 11.微处理器:也成中央处理器(CPU),是微型计算机的核心部件,包含运算器、控制器、寄存器组及总线接口等,负责对计算机系统各部件进行统一的协调和控制。 12.寻址方式:就是寻找操作数或操作数地址的方式,根据寻址方式可方便地访问各类操作数。 13.伪指令:是发送给汇编程序的命令,在汇编过程中由汇编程序进行处理,如定义数据、分配存储区、定义段及定义过程等。 14.中断源:指能引起中断的外部设备或内部原因。 15.汇编语言:是一种面向CPU指令系统的程序设计语言,采用指令助记符来表示操作码和操作数,用符号地址表示操作数地址。 三、简答题(本大题共4小题,每小题5分,共20分) 16.微型计算机系统软件的主要特点是什么? 计算机系统软件的主要特点是简化计算机操作,支持应用软件的运行并提供相关服务,通常包括操作系统、语言处理程序等。 17.什么是逻辑地址?他由哪两部分组成? 计算机存储器中给每个逻辑段编址的地址称逻辑地址。逻辑地址是在程序中使用的地址,他由段地址和偏移地址两部分构成。 18.一个完整的汇编源程序由那些逻辑段组成?各逻辑段的主要作用是什 么? 一般情况下汇编语言源程序应该由以下3个逻辑段组成: ①数据段:用来在内存中建立一个适当容量的工作区,以存放常数, 变量等程序需要对其进行操作的数据;

②堆栈段:用来在内存中建立一个适当容量的堆栈区,以便在中断、 子程序调用时使用; ③代码段:包括了许多以符号表示的指令,其内容就是程序需要执行 的具体操作。 19. DMA数据传送方式的特点是什么? DMA数据传送方式把外设与内存交换信息的操作与控制交给DMA控制器,简化了CPU对数据交换的控制,数据传送速度快,但这种方式电路结构复杂,硬件开销大。 20. 简述中断技术的优点。 ①CPU与外设可并行操作。 ②可对实时信息进行采集、处理和控制。 ③可对计算机出现的故障进行随机处理。 四、计算与分析(本大题共3小题,每小题5分,共15分) 21. 请将(158.625)10转为二进制。 结果:(10011110.101)2 22. 若一个程序段开始执行前,(CS)=33A0H,(IP)=0130H,则该程序段 启动执行指令的实际地址PA是多少? PA=(CS)×10H+(IP)=33A0H×10H+0130H=33B30H 23. 有两个16位的字31DAH和5E7FH,它们在8086系统存储器中的地址 分别为00130H和00134H,试画出它们的存储示意图。

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

汇编语言程序设计习题解答 1.指出下列指令的错误: (1)MOV AH,BX (2)MOV [BX],[SI] (3)MOV AX,[SI][DI] (4)MOV MYDAT[BX][SI],ES:AX (5)MOV BYTE PTR[BX],1000 (6)MOV BX,OFFSET MYDAT[SI] (7)MOV CS,AX 答:(1)MOV AH,BX AH 为八位,BX为16位 (2)MOV [BX],[SI] 两个操作数不能都是存储单元 (3)MOV AX,[SI][DI] 一个操作数中不能用两个变址寄存器 (4)MOV MYDAT [BX][SI],E8:AX ES ES 后应为一个变址寄存器,表示偏移量 (5)MOV BYTE PTR[BX],1000 BYTE 说明时BX进行字节操作。而1000为字 (6)MOV BX,OFFSET MYDAT [SI] OFFSET 为取某个地址的偏移量,故后面不应用[SI],而应是一个符号地址。 (7)MOV 是数据寻址,不应用程序段寄存器CS. 2.下面哪些指令是非法的?(假设OPl,OP2是已经用DB定义的变量) (1)CMP l5,BX (2)CMP OPl,25 (3)CMP OPl,OP2 (4)CMP AX,OPl 答:(1) CMP 15,BX 非法,两个操作数不能一个为字,一个为字节 (2)CMP OP1,25 正确 (3)CMP OP1,OP2 正确 (4)CMP AX,OP1 非法,两操作数不能一个为字,一个为字节 3.假设下列指令中的所有标识符均为类型属性为字的变量,请指出下列指令中哪些是非法的?它们的错误是什么? (1)MOV BP,AL (2)MOV WORD_OP[BX+4*3][DI],SP (3)MOV WORD_OPl,WORD_OP2 (4)MOV AX,WORD_OPl[DX] (5)MOV SAVE_WORD,DS (6)MOV SP,SS:DATA_WORD[BX][SI] (7)MOV [BX][SI],2 (8)MOV AX,WORD_ OPl+WORD_OP2 (9)MOV AX,WORD_ OPl-WORD_OP2+100 (10)MOV WORD_ OPl,WORD_ OPl-WORD_OP2 答:(1)MOV BP,AL

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

汇编语言程序设计习题及参考答案 习题一

1.1把下列2、8、16进制数转换成为十进制数 (1)(1011011)2(2)(0.10110)2(3)(111111.01)2(4)(1000001.11)2(5)(377)8(6)(0.24)8(7)(3FF)16(8)(2A.4)16 解:(1)(1011011)2=64+16+8+2+1=91 另解:原式=(5B)16=5×16+11=91 (2)(0.10110)2=0.5+0.125+0.0625=0.6875 (3)(111111.01)2=32+16+8+4+2+1+0.25=63.25 另解:原式=(1000000-1+0.01)2=64-1+0.25=63.25 (4)(1000001.11)2=64+1+0.5+0.25=65.75 (5)(377)8=3×64+7×8+7=255 另解:原式=(400-1)8=4×64-1=255 (6)(0.24)8=2×0.125+4×0.015625=0.3125 (7)(3FF)16=3×256+15×16+15=1023 另解:原式=(400-1)16=4×256-1=1023 (8)(2A.4)16=2×16+10+4×0.0625=42.25 另解:原式=2×16+10+4÷16=42.25 1.2 把下列十进制数转换为2、16进制数 (1)(127)10(2)(33)10(3)(0.3)10(4)(0.625)10 (5)(1023.5)10(6)(377)10(7)(1/1024)10(8)(377/32)10解:(1)(127)10 =64+32+16+8+4+2+1= (111 1111)2=(7F)16 另解:原式=(128-1)10=(1000 0000-1)2=(111 1111)2=(7F)16 (2)(33)10=32+1= (10 0001)2=(21)16 (3)(0.3)10 = (0.0100 1100 1……)2=(0.4CCC……)16 (4)(0.625)10= 0.5+0.125=(0.101)2=(0.A)16 (5)(1023.5)10 = 512+256+128+64+32+16+8+4+2+1+0.5 =(11 1111 1111.1)2=(3FF.8)16 (6)(377)10 =256+64+32+16+8+1=(1 0111 1001)2=(179)16 (7)(1/1024)10=(0.0000 0000 01)2=(0.004)16 (8)(377/32)10=(256+64+32+16+8+1)÷(32)= (101111001)2÷(100000)2 =(1011.11001)2=(0B.C1)16 1.3 把下列二进制数转换为十六进制数 (1)(100011)2(2)(0.11101)2(3)(11111.11)2(4)(0.00101)2解:(1)(100011)2=(10‟0011)2=23H (2)(0.11101)2=(0.1110‟1000)2=0.E8H (3)(11111.11)2=(1‟1111.1100)2=1F.CH (4)(0.00101)2=(0.0010‟1000)2=0.28H 1.4 把下列十六进制数转换为二进制数 (1)(3B6)16(2)(100)16(3)(80.2)16(4)(2FF.A)16解:(1)(3B6)16=(0011 1011 0110)2 (2)(100)16=(0001 0000 0000)2 (3)(80.2)16=(1000 0000.0010)2 (4)(2FF.A)16 =(0010 1111 1111.1010)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

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

第一章.习题 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位二进制补码计算下列各题,并用十六进 制数表示其运算结果。

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