(9)RCR DL,1 DL带进位循环右移1 0000 0000 1101 1101B = 00DDH
15. 选择题(各小题只有一个正确答案)
(1)执行下列三条指令后:
MOV SP,1000H PUSH AX CALL BX
a. (SP)=1000H; c. (SP)=1004H;
b. (SP)=0FFEH; d. (SP)=0FFCH;
(2)要检查寄存器AL中的内容是否与AH相同,应使用的指令为:
a. AND AL, AH
b. OR AL, AH
c. XOR AL, AH d. SBB AL, AH
(3)指令JMP NEAR PTR L1与CALL L1(L1为标号)的区别在于:
a. 寻址方式不同; c. 目的地址不同;
b. 是否保存IP的内容; d. 对标志位的影响不同。
解:(1)D (2)C (3)B
PUSHU AX则AX入栈,SP=0FFEH;CALL BX则IP入栈,SP=0FFCH 异或,若相同,则AL=0,ZF=1。
16. 寄存器DX:AX组成32位数,DX为高位,编写程序段实现:
(1)DX:AX右移3位,并将移出的低3位保存在CL中; (2)DX:AX左移3位,并将移出的高3位保存在CL中; 解:(1)移出的3位应该按时序移入CL中。
XOR CL,CL MOV BL,3
L1: SHR DX,1
RCR AX,1 RCL CL,1 DEC BL JNZ L1
(2)移出的3位应该按时序移入CL中。
XOR CL,CL
- 16 -
MOV BL,3
L1: SHL AX,1
RCR DX,1 RCR CL,1 DEC BL JNZ L1
17. 编写程序段实现将BL中的每一位重复4次,构成32位的双字DX:AX,例如当BL
=01011101B时,则得到的(DX)=0F0FH,(AX)=0FF0FH。
解:算术右移时,移入的值就是最高位本身,这样可以使位内容重复,利用这一点可以实现题目的要求。
XOR XOR MOV
DX,DX AX,AX CX,4 BL,1 AX,1 AX,1 AX,1 AX,1 L1 CX,4 BL,1
DX,1 DX,1 DX,1 DX,1 L2
L1: SHR
RCR SAR SAR SAR LOOP MOV
L2: SHR
RCR SAR SAR SAR LOOP
18. 字变量VAR1中保存有小于38250的16位无符号数,编写程序段实现VAR1÷150,并
进行四舍五入操作,将商保存在字节变量VAR2中。
解:根据题意,38250÷150=255,因此商不会超过255,可以用一个字节表示。
a÷b的四舍五入操作可以通过判断除后余数实现:余数大于等于除数的一半,则商加1;
- 17 -
否则不用加1。但这种方法用汇编语言编程实现时比较复杂,这里介绍另外一种方法:设a÷b的四舍五入后的结果为c,用『』表示取整数操作,则
b???a??a?2? c???0.5???b??b???这种方法是在除法操作之前,在被除数上加上除数的一半,这样除法操作后得到的值就是考虑了四舍五入的商。 VAR1
DW 12345
DB ?
DB 150
VAR2
DATAA
MOV AX,VAR1 XOR BX,BX MOV BL,DATAA SHR BX,1 ADD AX,BX DIV DATAA
MOV VAR2,AL
19. 有一组无符号的16位数据保存在BUFFER中,前两个字节存放数据的个数,编程实现
按下式进行滤波处理:
1?x(k)?x(k?1)?x(k?2)?3y(k)?x(k)y(k)?解:滤波结果保存在FILT中。
BUFFER DW 0CH
k?2k?2
DW 33H, 18H, 1BH, 06H, 33H, 08H DW 3H, 6H, 0FH, 51H, 05H, 0CH
LEA SI,BUFFER LEA DI,FILT
- 18 -
FILT DW 100H DUP(?)
MOV CX,[SI] MOV [DI],CX ADD SI,2 ADD DI,2 XOR DX,DX MOV AX,[SI] MOV [DI],AX MOV BX,2[SI] MOV 2[DI],BX ADD SI,4 ADD DI,4 DEC CX DEC CX ADD AX,BX ADC DX,0 MOV BX,3 L1:
ADD AX,[SI] ADC DX,0 PUSH DX PUSH AX DIV BX MOV [DI],AX POP AX POP DX SUB AX, [SI-4] SUBB DX,0 ADD DI,2 ADD SI,2 LOOP L1
19 -
-