汇编课后答案

更新时间:2024-03-20 19:02:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

1、 什么是堆栈?他的工作原则是什么?它的基本操作有哪两个?对应哪两种指令? 堆栈是一种按“先进后出”原则存取数据的存储区域。 堆栈的两种基本操作是压栈

和出栈,对应的指令是PUSH和POP。

第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 pop bx

pop [bx]

〔解答〕 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,89h add al,al add al,9dh cmp al,0bch

sub al,al dec al inc al 〔解答〕

mov al,89h ; AL=89h CF ZF SF OF PF add al,al ; AL=12h 1 0 0 1 1

add al,9dh cmp al,0bch sub al,al dec al inc al ; 1000 1001 +1000 1001 10001 0010

; AL=0afh 0 0 1 0 1

; 0001 0010 + 1001 1101 1010 1111

; AL=0afh 1 0 1 0 1

; 1010 1111 -1011 1100 * 0100 0011

; AL=00h 0 1 0 0 1

; AL=0ffh 0 0 1 0 1

; 0000 0000 - 0000 0001 *1111 1111

; AL=00h 0 1 0 0 1

;1111 1111 +0000 0001

*1111 1111

〔习题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寄存器。

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

果送到AL中。

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

并把结果送回存储器中。

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

储单元中。

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

〔解答〕 (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均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,

得出它的运算公式,并说明运算结果存于何处。

mov ax,X ;ax=X imul Y ;DX.AX=X*Y

mov cx,ax ;cx=X*Y的低16位 mox bx,dx ;bx=X*Y的高16位

mov ax,Z ;ax=Z

cwd

add cx,ax ;cx=Z的低16位+X*Y的低16位 adc bx,dx ;bx=Z的高16位+X*Y的高16位+低位进位

sub cx,540 ;cx=Z的低16位+X*Y的低16位-540

sbb bx,0 ;bx=Z的高16位+X*Y的高16位+低位进位-低位借位

mov ax,V ;ax=V

cwd

sub ax,cx ;ax=V的低16位-(Z的低16位+X*Y的低16位-540)

sbb dx,bx ;dx=V的高16位-(Z的高16位+X*Y的高16位+低位进位-低位借位)-低位

借位

idiv X ;/X

〔解答〕

[V-(X*Y+Z-540)]/X AX存商,DX存余数

〔习题2.10〕指出下列指令的错误:

(1) xchg [si],30h (2) pop cs (3) sub [si],[di] (4) push ah (5) adc ax,ds (6) add [si],80h (7) in al,3fch (8) out dx,ah

〔解答〕

(1)xchg的操作数不能是立即数

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

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

mov ax,1470h and ax,ax or ax,ax xor ax,ax not ax test ax,0f0f0h

〔解答〕

mov ax,1470h ;AX=1470H CF ZF SF OF PF

and ax,ax ;AX=1470H 0 0 0 0 0

;0001 0100 0111 0000

or ax,ax ;AX=1470H 0 0 0 0 0 xor ax,ax ;AX=0000H 0 1 0 0 1 not ax ;AX=FFFFH 0 1 0 0 1 test ax,0f0f0h ;AX=FFFFH 0 0 1 0 1

注意:MOV和NOT指令不影响标志位;其他逻辑指令使CF=OF=0,根据结果影响其他标志位。

〔习题2.12〕假设例题2.32的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结果和各个标

志位的状态。

〔解答〕

指令 ; 执行结果 CF OF SF ZF PF mov si,ax ; SI=AX=0008H - - - - - shl si,1 ; SI=2*AX=0010H 0 0 0 0 0 add si,ax ; SI=3*AX=0018H 0 0 0 0 1 mov dx,bx ; DX=BX=0010H 0 0 0 0 1 mov cl,03h ; CL=03H 0 0 0 0 1 shl dx,cl ; DX=8*BX=0080H 0 u 0 0 0 sub dx,bx ; DX=7*BX=0070H 0 0 0 0 0 add dx,si ; DX=7*BX+3*AX=0088H 0 0 0 0 1

注意:逻辑左移N次相当于无符号整数乘以2的N次方,逻辑右移N次相当于无符号整数除以2

的N次方。移位指令根据移位的数据设置CF,根据移位后的结果影响SF,ZF,PF。在进行一位移位时,根据最高符号位是否改变设置OF,如改变则OF=1。另外,程序注释用“u”表示标志无定义(不确定),

“-”表示无影响。

〔习题2.13〕编写程序段完成如下要求: (1)用位操作指令实现AL(无符号数)乘以10

(2)用逻辑运算指令实现数字0 ~ 9的ASCII码与非压缩BCD码的互相转换

(3)把DX.AX中的双字右移4位

〔解答〕

(1) ;不考虑进位

mov bl,al mov cl,3

shl al,cl ;*8 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

(3) mov cl,4

again: shr dx,1 ;实现逻辑右移

;采用“sar dx,1”,则实现算术右移

rcr ax,1 dec cl jnz again

〔习题2.14〕已知AL = F7H(表示有符号数-9),分别编写用SAR和IDIV指令实现的除以2的程序段,

并说明各自执行后,所得的商是什么?

〔解答〕 (1)用sar编写

mov al,0f7h ; -9送AL 1111 1001

sar al,1 ; 结果:AL=1111 1100B=0FBH 即-5

(2)用idiv编写

mov al,0f7h ; -9送al cbw ; 字节符号扩展位字 mov bl,2 ; 注意除数不可为立即数 idiv bl ; 结果:商为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

〔解答〕

将es:di (即3000:2000h或32000h)开始的5个单元的内容置为0fefh。

〔习题2.17〕指令指针IP是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指令的执行会

改变它的值?

〔解答〕

指令指针IP不是通用寄存器,不可直接赋值,属于专用寄存器。有且仅有循环、转移、子程序调用

和返回、中断类等指令可以改变它的值。

〔习题2.18〕控制转移类指令中有哪三种寻址方式?

〔解答〕

控制转移类指令的寻址方式:相对寻址、直接寻址方式和间接寻址方式(又可以分成寄存器和存储

器间接寻址)。

〔习题2.19〕什么是短转移short jump、近转移near jump和远转移far jump?什么是段内转移和段间

转移?8086有哪些指令可以实现段间转移?

〔解答〕

短转移:指段内-128~127之间的转移,位移量用一个字节表示

近转移:指段内±32K之间的转移,位移量用一个字表示

远转移:指段间1MB范围的转移

段内转移:指在同一个代码段内的转移,可以是短转移或者近转移

段间转移:指转移到另外一个代码段,就是远转移

8086/8088CPU的JMP、CALL和INT n指令可以实现段间转移

〔习题2.20〕8086的条件转移指令的转移范围有多大?实际编程时,你如何处理超出范围的条件转移?

〔解答〕

8086的条件转移的转移范围:在当前指令地址的 +127~-128之内。

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

址。

〔习题2.21〕假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,

[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?

(1) JMP BX (2) JMP TABLE[BX] (3) JMP [BX][SI]

〔解答〕

(1)转移的有效地址EA= BX=1256H

(2)转移的有效地址EA= [DS:20A1H+1256H]=[232F7]=3280H (3)转移的有效地址EA= [DS:1256H+528FH]=264E5H=2450H

〔习题2.22〕判断下列程序段跳转的条件

(1) xor ax,1e1eh je equal (2)test al,10000001b

jnz there (3)cmp cx,64h jb there

〔解答〕

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

(2)AL的D0或D7至少有一位为1

(3)CX(无符号数)< 64h

〔习题2.23〕设置CX = 0,则LOOP指令将循环多少次?例如:

mov cx,0 delay: loop delay

〔解答〕 216次。

〔习题2.24〕假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移

指令实现以下判断:

(1)若DX > DI,转到above执行; (2)若AX > SI,转到greater执行; (3)若CX = 0,转到zero执行;

(4)若AX-SI产生溢出,转到overflow执行;

(5)若SI≤AX,转到less_eq执行; (6)若DI≤DX,转到below_eq执行。

〔解答〕

(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

jz zero ;= jcxz zero (4)若AX-SI产生溢出,转到overflow执行;

cmp ax,si 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寄存器。

(2)从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低(高)地址对低(高)位

的原则,将它们合并到DX中。

(3)编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1。

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

buffer1-buffer2功能。

(5)假设从B800h : 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存

在DX.AX中。

(6)已知字符串string包含有32KB内容,将其中的?$?符号替换成空格。

(7)有一个100个字节元素的数组,其首地址为array,将每个元素减1(不考虑溢出)存于原处。

(8)统计以 ?$? 结尾的字符串srting的字符个数。

〔解答〕 (1)解答: mov si,0

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

mov si,5

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

(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 ; test dh,0f0h

jz next ; jnz next mov ax,-1 ; mov ax,0

jmp again

next: mov ax,0 ; mov ax,0ffffh

again: ... (4)解答:

mov ax, word ptr buffer1

sub ax, word ptr buffer2 ;先减低16位

mov dx, word ptr buffer1+2

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.35〕补充例2.42,显示“1”的个数;注意首先将个数转换为ASCII码。

〔解答〕

and al,7fh ;使d7=0 mov dl,al ;转存于dl jnp next ;奇数个1转 or al,80h ;偶数个1 使d7=1 next: xor bl,bl ;纪录1的个数 dl=0

mov cx,8 ;移位次数 again: shl dl,1 ;逻辑左移1次 jnc desp ;如cf=0 转 inc bl ;否则cf=1 个数加1 desp: loop again ;cx=cx-1 如cx不等于0,循环

or bl,30h ;个数变为ASCII码 mov ah,02h ;在CRT上显示个数

mov dl,bl int 21h ret

〔习题2.36〕先提示输入数字“Input Number:0 ~ 9”,然后在下一行显示输入的数字,结束;如果不是

键入了0 ~ 9数字,就提示错误“Error!”,继续等待输入数字。

〔解答〕 ; 数据段

str1 db 'Input Number:0~9 : ',0dh,0ah,'$'

str2 db 'Error!',0dh,0ah,'$'

; 代码段

mov ah,09h ; 显示str1字符串

mov dx,offset str1

int 21h

getkey: mov ah,1 ; 调用DOS功能

int 21h cmp al,'0'

jb error ; 小于0,出错处理

cmp al,'9'

ja error ; 大于9,出错处理

mov ah,02h ; 调用DOS显示字符功能,显示该数字

mov dl,al int 21h

... ; 终止程序执行,返回DOS

error: mov ah,09h ; 出错,调用DOS 功能显示str2字符串

mov dx,offset str2

int 21h

jmp getkey ; 返回按键

〔习题2.37〕从键盘输入一个字符串(不超过255个),将其中的小写字母转换成大写字母,然后按原来

的顺序在屏幕上显示。

〔解答〕

思路:参考P67 例2.52用0ah号DOS系统功能调用,从键盘输入一个字符串,然后从键盘缓冲区逐个取字符,在“a”与“z”之间的字符为小写字母,需要转换为大写字母(减去20h),其他不变。

;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

〔习题2.38〕指令对状态标志的作用可以分成多种情况,例如无影响、无定义、按结果影响、特别说明的

影响等,你能区别这些情况吗?分别用具体的指令来说明。

〔解答〕

〔习题2.39〕8086指令系统分成哪6个功能组?各组主要包含什么指令,举例说明。

〔解答〕

8086指令系统分成的6个功能组是

(1)数据传送类令:

①通用数据传送指令如传送指令MOV、交换指令XCHG、换码指令XLAT

②堆栈操作指令如进栈指令PUSH出栈指令POP ③标志传送指令如标志寄存器传送;标志位操作

④地址传送指令如有效地址传送指令LEA、指针传送指令LDS指针传送指令LES

⑤输入输出指令如输入指令IN、输出指令OUT

(2)算术运算指令

①加法指令如加法指令ADD、带进位加法指令ADC、增量指令INC

②减法指令如减法指令SUB、带借位指令SBB、减量指令DEC、求补指令NEG、比较指令CMP

③乘法指令如无符号乘法指令MUL、有符号乘法指令IMUL ④除法指令如无符号数除法指令DIV、有符号数除法指令IDIV ⑤符号扩展指令如字节转换字指令CBW、字转换字节指令CWD ⑥十进制调整指令如压缩BCD码调整指令、非压缩BCD码调整指令

(3)位操作类指令

①逻辑运算指令如逻辑指令AND、逻辑或指令OR、逻辑异或指令XOR、逻辑非指令NOT、测试

指令TEST

②移位指令如逻辑移位指令SHL和SHR、算术移位指令SAL和SAR ③循环移位指令如不带移位指令XOL和ROR、带移位指令RCL和RCR

(4)控制转移类指令 ①无条件转移指令JMP

②条件转移指令如判断单个标志状态JZ/JE、JNZ/JNE、JS/JNS、JP/JPE、JNP/JPO、JC/JB、JNC/JNB/JAE,用于比较无符号数高低JB(JNAE)、JNB(JAE)、JBE(JNA)、JNBE(JA),用于比较有符

号数大小JL(JNGE)、JNL(JGE)、JLE(JNG)、JNLE(JG)

③循环指令LOOP

④子程序指令如子程序调用指令CALL、子程序返回指令RET

⑤中断指令如INT N (5)串操作类指令 ①串传送指令MOVS ②串存储指令STOS ③串读取指令LODS ④串比较指令CMPS

(1)1000超出了一个字节范围

(2)寄存器的值只有程序执行时才能确定,而offset是汇编过程计算的偏移地址,故无法确定,改

为lea bx,myword[si]

(3)两个都是存储单元,指令不允许

(4)变量值只有执行时才确定,汇编过程不能计算 (5)字节量AL与字量myword,类型不匹配 (6)Jcc指令只有相对寻址方式,不支持间接寻址方式

〔习题3.10〕OPR1是一个常量,问下列语句中两个AND操作有什么区别?

AND AL,OPR1 AND 0feh

〔解答〕

前者为“与”操作硬指令助记符,可汇编成机器代码。 后者为逻辑运算符,在汇编时进行“与”运算,产生具体数值。

〔习题3.11〕给出下列语句中,指令立即数(数值表达式)的值:

(1) mov al,23h AND 45h OR 67h

(2) mov ax,1234h/16+10h (3) mov ax,NOT(65535 XOR 1234h) (4) mov al,LOW 1234h OR HIGH 5678h

(5) mov ax,23h SHL 4 (6) mov ax,1234h SHR 6 (7) mov al,?a? AND (NOT(?a?-?A?)) (8) mov al,?H? OR 00100000b (9) mov ax,(76543 LT 32768) XOR 7654h

〔解答〕

注:对于逻辑运算,有关操作数可化为二进制数。

(1)67h (2)133h (3)1234h (4)76h (5)0234h (6)0048h

(7)41h (8)68h (9)7654h

〔习题3.12〕为第2章例题2.54定义变量count、block、dplus和dminus。

〔解答〕

假设block开始的数据块有32个字节数据:16个正数+100 (64h)、16个负数 -48 (0d0h)

分别连续分布:

block db 16 dup(100),16 dup(-48) ;也可以是任意字节数据,随意分布。

dplus db 32 dup(?) ;为正数预留存储空间 dminus db 32 dup(?) ;为负数预留存储空间

count equ 32 ;字节数

〔习题3.13〕为第2章例题2.55定义相应变量,并形成一个完整的汇编语言程序。

〔解答〕 ;lt239b.asm .model small

.stack .data

string1 db 'good morning !' ;两字符串可相同或不同,但字符数要求相同。

string2 db 'Good morning !' result db ? ;预留结果字节 count = 14 ;字符数

.code .startup

mov ax,ds ;所有数据在同一个段,所以使es=ds

mov es,ax mov si,offset string1 mov di,offset string2

mov cx,count again: cmpsb

jnz unmat dec cx jnz again mov al,0 jmp output unmat: mov al,0ffh output: mov result, al

.exit0 end

〔习题3.14〕画图说明下列语句分配的存储空间及初始化的数据值:

(1) byte_var DB ?ABC?,10,10h,?EF?,3 DUP(-1,?,3 DUP(4))

(2) word_var DW 10h,-5,?EF?,3 DUP(?)

〔解答〕

(1)从低地址开始,依次是(十六进制表达):

41 42 43 0a 10 45 46 ff - 04 04 04 ff - 04 04 04 ff - 04 04 04

(2)从低地址开始,依次是(十六进制表达): 10 00 FB FF 46 45 - - - - - -

〔习题3.15〕请设置一个数据段mydataseg,按照如下要求定义变量:

(1) my1b为字符串变量:Personal Computer (2) my2b为用十进制数表示的字节变量:20 (3) my3b为用十六进制数表示的字节变量:20 (4) my4b为用二进制数表示的字节变量:20

(5) my5w为20个未赋值的字变量

(6) my6c为100的常量

(7) my7c表示字符串:Personal Computer

〔解答〕 mydataseg segment my1b db ?Personal Computer?

my2b db 20

my3b db 14h ;20h my4b db 00010100b my5w dw 20 dup(?)

my6c equ 100 ;my6c = 100 my7c equ

mydataseg ends

〔习题3.16〕分析例题3.2的数据段,并上机观察数据的存储形式。

〔解答〕

以字节为单位从低地址向高地址依次是:

16 00 12

FFH FFH FFH FFH 00 00 00 00 00 00 00 00

1 2 3 4 5

45H 23H 00 00 00 00 00 00 00 00

?a? ?b? ?c?

?H? ?e? ?l? ?l? ?o? 13 10 ?$?

12个字符串?month?,每个字符串从低地址到高地址依次是:?m? ?o? ?n? ?t? ?h?

25×4个字节未定义初值的存储单元,操作系统设置为0

〔习题3.17〕修改例题3.3,现在用字定义伪指令dw、字串传送指令movsw和字符串显示9号功能调用

实现。 〔解答〕 .model small .stack .data

source dw 3433h,3635h target dw 40 dup(?),'$'

.code .startup mov ax,ds

mov es,ax

cld

mov si,offset source mov di,offset target

mov cx,40 rep movsw mov si,0 mov dx,offset target

mov ah,9 int 21h .exit 0 end

〔习题3.18〕变量和标号有什么属性?

〔解答〕

段地址:表示变量和标号所在代码段的段地址; 偏移地址:表示变量和标号所在代码段的段内偏移地址;

类型:引用变量时,表示是字节、字、双字等数据量。引用该标号时,表示它所在同一个段――near

类型,还是另外一个段――far类型。

〔习题3.19〕设在某个程序中有如下片段,请写出每条传送指令执行后寄存器AX的内容:

mydata segment ORG 100H VARW DW 1234H,5678H

VARB DB 3,4 ALIGN 4 VARD DD 12345678H

EVEN BUFF DB 10 DUP(?) MESS DB ?HELLO? BEGIN: MOV AX,OFFSET MESS

MOV AX,TYPE BUFF+TYPE MESS+TYPE VARD

结构名 STRUCT … ;数据定义语句

结构名 ENDS 结构变量定义的格式为: 变量名,结构名 〈字段初值表〉 引用结构字段,采用圆点“.”操作符,其格式是:

结构变量名.结构字段名。

〔习题3.30〕记录数据类型如何说明,记录变量如何定义,width和mask操作符是什么作用?

〔解答〕

记录类型的说明采用伪指令RECORD,它的格式为:

记录名 RECORD 位段[,位段…]

定义记录变量的格式: 记录变量名 记录名 〈段初值表〉

Width记录名/记录位段名操作符返回记录或记录位段所占用的位数。

mask记录位段名操作符返回一个8位或16位数值,其中对应该位段的个位为1,其余位为0。

第1章 汇编语言基础知识

〔习题1.1〕简述计算机系统的硬件组成及各部分作用。

〔解答〕

CPU:包括运算器、控制器和寄存器组。运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为

处理单元提供所需要的数据。

存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。

外部设备:实现人机交换和机间的通信。

〔习题1.2〕明确下列概念或符号:

主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB

〔解答〕

主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速

度慢。

RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电

后能保存信息。

存储器由大量存储单元组成。为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常

称做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)FFH 11111111B 255D (2)0H 0B 0D (3)5EH 1011110B 94D (4)EFH 11101111B 239D (5)2EH 101110B 46D (6)10H 10000B 16D (7)1FH 11111B 31D (8)ABH 10101011B 171D

〔习题1.6〕

将下列十进制数转换为BCD码表示

(1)12 (2)24 (3)68 (4)127 (5)128 (6)255 (7)1234 (8)2458

〔解答〕

(1)12 00010010 (2)24 00100100 (3)68 01101000 (4)127 000100100111 (5)128 000100101000 (6)255 001001010101 (7)1234 0001001000110100 (8)2458 0010010001011000

〔习题1.7〕

将下列BCD码转换为十进制数

(1)10010001 (2)10001001 (3)00110110 (4)10010000 (5)00001000 (6)10010111 (7)10000001 (8)00000010

〔解答〕 (1)91 (2)89 (3)36

(4)90 (5)08

(6)97 (7)81

(8)02

〔习题1.8〕将下列十进制数分别用8位二进制数的原码、反码和补码表示

(1)0 (2)-127 (3)127 (4)-57 (5)126 (6)-126 (7)-128 (8)68

〔解答〕

(1)0 +0 00000000 00000000 00000000 -0 10000000 11111111 00000000 (2)-127 11111111 10000000 10000001 (3)127 01111111 01111111 01111111 (4)-57 10101111 11010000 11010001 (5)126 01111110 01111110 01111110 (6)-126 11111110 10000001 10000010 (7)-128 10000000 (8)68 01000100 01000100 01000100

〔习题1.9〕完成下列二进制数的运算

(1)1011+1001 (2)1011-1001 (3)1011×1001 (4)10111000÷1001 (5)1011 ? 1001 (6)1011 ? 1001 (7)~1011 (8)1011 ? 1001

〔解答〕

(1)1011+1001=10100 (2)1011-1001=0010 (3)1011×1001=1100011

(4)10111000÷1001=10100,余数 1000

(5)1011 ? 1001=1001 (6)1011 ? 1001=1011 (7)~1011=011 (8)1011 ? 1001=0010

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

0ah对应的是什么字符?

〔解答〕

数码0~9:30H~39H 大写字母A~Z:41H~5AH 小写字母a~z:61H~7AH

ASCII码为0dh、0ah分别对应回车和换行控制字符。

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

它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?

〔解答〕

十进制无符号数:01100001B=61H=97

BCD码:61 ASCII码:a

〔习题1.12〕简述Intel 80x86系列微处理器在指令集方面的发展。

〔解答〕

1978年Intel,正式推出了16位8086CPU,1979年Intel推出了准16位微处理器8088,随后,Intel推出了80186/80188,80186/80188指令系统比8086指令系统新增了若干条实用的指令,涉及堆栈操作、移位指令、过程指令和边界检测及乘法指令,1982年Intel推出80286 CPU, 80286指令系统包括全部80186指令及新增的保护指令15条,其中有些保护方式在实方式下也可以使用,1985年,Intel80x86推出微处理器地进入第三代80386 CPU, 80386指令系统在兼容原来16位指令系统的基础上,全面升级为32位,还新增了有关位操作、条件设置指令以及控制、调试和测试寄存器的传送指令等,1989年,Intel推出了80486CPU,80486将浮点处理单元FPU集成进来,还采用了精简指令集计算机技术RISC和指令流水线方式,还新增了用于多处理器和内部Cache操作的6条指令,1993年Intel制成了俗称586的微处理器,取名Pentium。Pentium仍为32位结构,地址总线为32位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium新增了一条8字节比较交换指令和一条处理器识别指令,以及4条系统专用指令,1996年推出了MMX Pentium,新增了57条多媒休指令,1995年Intel推出Pentium Pro新增了3条指令,1999年推出了PentiumⅢ新增了70条SSE指令,2000年推出的Pentium4新增了76条SSE2

指令

〔习题1.13〕什么是DOS和ROM-BIOS?

〔解答〕

DOS是Diskette Operating system的缩写,意思是磁盘操作系统,DOS主要是面向磁盘的系统软件,说得简单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层“外壳”,是1981~1995年的个人电脑上使用的一种主要的操作系统。BIOS(Basic Input/Output System)即基本输入输出系统,通常是固化在只读存储器(ROM)中,所以又称为ROM-BIOS。它直接对计算机系统中的输入、输出设备进行设备级、硬件级的控制,是连接软件程序和硬件设备之间的枢纽。ROM-BIOS是计算机系统中用来提供最低

级、最直接的硬件控制的程序。

〔习题1.14〕简述PC机最低1MB主存空间的使用情况。

〔解答〕

(1)基本RAM区(00000H—9FFFFH)该区共640KB,由DOS进行管理。在这个区域中操作系统

要占用掉一部分低地址空间,其它则向用户程序开放。

(2)保留区RAM(A0000H--BFFFFFH)该区为系统安排的“显示缓冲存储区”,共126KB,是显卡上的芯片提供支持,用于存放屏幕显示信息。但这部分地址空间实际上并没有全部使用。

本文来源:https://www.bwwdw.com/article/qmo8.html

Top