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

上传人:b****6 文档编号:6547577 上传时间:2023-01-07 格式:DOCX 页数:32 大小:65.60KB
下载 相关 举报
汇编语言程序设计习题答案.docx_第1页
第1页 / 共32页
汇编语言程序设计习题答案.docx_第2页
第2页 / 共32页
汇编语言程序设计习题答案.docx_第3页
第3页 / 共32页
汇编语言程序设计习题答案.docx_第4页
第4页 / 共32页
汇编语言程序设计习题答案.docx_第5页
第5页 / 共32页
点击查看更多>>
下载资源
资源描述

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

《汇编语言程序设计习题答案.docx》由会员分享,可在线阅读,更多相关《汇编语言程序设计习题答案.docx(32页珍藏版)》请在冰豆网上搜索。

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

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

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

第一章汇编语言基础知识

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 ⊕10011001(6)1011 ∨1001(7)

1.10 数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?

ASCII码为0dh、0ah对应的是什么字符?

1.11、计算机中有一个“01100001”编码,如果把它认为是无符号数,它是10进制什么数?

如果认为它是BCD码,则表示什么数?

又如果它是某个ASCII码,则代表哪个字符?

 

1.12、简述Intel80x86系列微处理器在指令集方面的发展。

 

1.13、什么是DOS和ROM-BIOS?

 

1.14、简述PC机最低1MB主存空间的使用情况。

 

1.15、罗列8086CPU的8个8位和16位通用寄存器 ,并说明各自的作用。

1.16、什么是标志,它有什么用途?

状态标志和控制标志有什么区别?

画出标志寄存器FLAGS,说明各个标志的位置和含义。

 

1.17、举例说明CF和OF标志的差异。

 溢出标志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;AX=1200h 

    

(2) mov ax,bx;AX=0100h 

    (3) mov ax,[1200h];AX=4C2Ah 

    (4) mov ax,[bx];AX=3412h 

    (5) mov ax,[bx+1100h];AX=4C2Ah 

    (6) mov ax,[bx+si];AX=7856h 

    (7) mov ax,[bx][si+1100h];AX=65B7h 

2.2指出下列指令的错误

(1)  mov cx,dl    两操作数类型不匹配 

(2)  mov ip,axIP指令指针禁止用户访问 

(3)  mov es,1234h 立即数不允许传给段寄存器 

(4)  mov es,ds段寄存器之间不允许传送 

(5)  mov al,300  两操作数类型不匹配 

(6)  mov [sp],ax目的操作数应为[ BP ] 

(7)  mov ax,bx+di 源操作数应为 [BX+DI] 

(8) mov 20h,ah立即数不能作目的操作数

2.3已知数字0 ~ 9对应的格雷码依次为:

18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址(设为200H)的连续区域中。

请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。

lea bx,table ;获取table的首地址,BX=200H 

mov 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的状态:

 mov al,89hAL=89h CF ZF SF OF PF 

add al,alAL=12h 1 0 0 1 1 

add al,9dhAL=0afh 0 0 1 0 1 

 cmp al,0bchAL=0afh 1 0 1 0 1 

 sub al,alAL=00h 0 1 0 0 1 

dec alAL=0ffh 0 0 1 0 1 

  inc alAL=00h 0 1 0 0 1 

 2.7 设X、Y、Z均为双字数据,分别存放在地址为X、X+2;Y、Y+2;Z、Z+2的存储单元中,它们的运算结果存入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

2.8请分别用一条汇编语言指令完成如下功能:

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

ADD DX,BX 

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

ADD AL,[BX+SI] 

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

ADD [BX+0B2H],CX

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

ADD WORD PTR [0520H],3412H

(5)把数0A0H与AL寄存器的内容相加,并把结果送回AL中。

ADD AL,0A0H 

2.9;设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。

为了避免与操作数地址混淆,将题中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 [si],30h  xchg的操作数不能是立即数 

(2)pop cs不能对CS直接赋值 

(3) sub [si],[di]  两个操作数不能都是存储单元 

(4)push ah堆栈的操作数不能是字节量 

(5) adc ax,ds adc的操作数不能是段寄存器 

(6) add [si],80h没有确定是字节还是字操作 

(7) in al,3fch in不支持超过FFH的直接寻址 

(8) out dx,ahout只能以AL/AX为源操作数

2.11;给出下列各条指令执行后的结果,以及状态标志CF、OF、SF、ZF、PF的状态。

  指令AX的值CFOFSFZFPF

Mov ax,1407h1470h-----

And ax,ax1470h00000

Or ax,ax1470h00000

Xor ax,ax000011

Not ax0ffffh-----

Test ax,0f0f0h0ffffh00101

注意:

 1. mov, not指令不影响标志位 

 2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位。

 

2.12;假设例题2.32的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结果和各个标志位的状态。

指令                 注释              执行结果   CFOFSFZFPF

movsi,ax           si=ax             si=0008h     -  -  -  -  -

shlsi,1            si=2*ax           si=0010h     0  0  0  0  0

addsi,ax           si=3*ax           si=0018h     0  0  0  0  1

movdx,bx           dx=bx             dx=0010h    -  -  -  -  -

movcl,03h          cl=03h                         -  -  -  -  -

shldx,cl           dx=8*bx           dx=0080h     0  u  0  0  0

subdx,bx           dx=7*bx           dx=0070h     0  0  0  0  0

adddx,si           dx=7*bx+3*ax    dx=0088h     0  0  0  0  1

注意:

 

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 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码与非压缩BCD码的互相转换

数字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 

(3) 把DX:

.AX中的双字右移4位

MOVCL,4

SHRAX,CL

MOVBL,DL

SHRDX,CL

SHLBL,CL

ORAH,BL

2.14; 已知AL = F7H(表示有符号数-9),分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得的商是什么?

(1)用sar编写 

moval,0f7h     ;-9送al

    saral,1        ;结果:

al=0fbh  即-5

(2)用idiv编写

     moval,0f7h    ;-9送al

     cbw            ;字节符号扩展位字

     movbl,2       ;注意除数不可为立即数

     idivbl        ;结果:

商为al=fch  (-4)

                    ;余数为ah=ffh(-1)  

    结论:

符号数的除法用idiv准确

2.15、已知数据段500h ~600h处存放了一个字符串,说明下列程序段执行后的结果:

    mov si,600h

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和INTn指令可以实现段间转移

2.20; 8086的条件转移指令的转移范围有多大?

实际编程时,你如何处理超出范围的条件转移?

8086的条件转移的转移范围:

在当前指令地址的 +127---- -128之内。

 

如条件转移的转移范围超出此范围,可在此范围内安排一条无条件转移,再转移到范围外的目标地址。

2.21; 假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?

(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)xorax,1e1eh

       jeequal

    ;AX=1e1eh(异或后为0)

(2)testal,10000001b

      jnzthere

    ;AL的D0或D7至少有一位为1

(3)cmpcx,64h

       jbthere

    ;CX(无符号数)<64h

2.23;设置CX = 0,则LOOP指令将循环多少次?

例如

mov cx,0 ;不循环,因为一进入循环就判 cx=0?

 如cx=0 就退出循环 

delay:

loop delay 

循环次数是2的16次方,即2^16=65536。

2.24 假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:

(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个字的数组,说明下列程序段的功能。

    mov cx,20

    mov ax,0

    mov si,ax

sum_loop:

 

    add ax,array[si]

    add si,2

    loop sum_loop

    mov total,ax

; 答:

将首地址为array得20个字的数组求和,并将结果存入 total 单元中。

2.26 按照下列要求,编写相应的程序段:

(1) 起始地址为string的主存单元中存放有一个字符串(长度大于6),把该字符串中的第1个和第6个字符(字节量)传送给DX寄存器。

 mov si,0 

 mov dl,string[si] ;第1个字符送dl寄存器 

 mov si,5 

 mov dh,string[si] ;第6个字符送dh寄存器 

(2) 从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低(高)地址对低(高)位的原则,将它们合并到DX中。

 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) 编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1。

 test dx,0f000h 

 jz zero 

 mov ax,-1 

 jmp done 

 zero:

 mov ax,0 

 done:

 ret 

(4) 有两个64位数值,按“小端方式”存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1-buffer2功能。

 lea bx,buffer1 

 lea dx,buffer2 

 mov cx,8 ;8个字节 

 xor si,si ;si=0 

 clc ;CF=0 

(5) 假设从B800h :

 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在DX.AX中。

 mov ax,0b800h 

 mov ds,ax ;段地址 

 xor si,si ;地址偏移量si=0 

 xor dx,dx ;和的高字dx=0 

 mov cx,99 ;加的次数 

 mov ax,[si] ;第一个数 

aga

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 院校资料

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1