校验方法为:对字符及字符,之间的7个ASCII字符进行异或操作,若异或操作结果的ASCII字符表示(异或操作结果高4位的ASCII字符表示在前,低4位的ASCII字符表示在后)与原字符串中字符,之后的两个ASCII字符相同,则将原字符串原样保存:反之,则将原字符串中的所有字符(共13个)均用字符!(21H)代替。
例如:
内存中有:33H,35H,23H('',第一个字符串开始),46H,41H,30H,2EH,34H,3DH,31H,2AH(''),32H,
31H,ODH,OAH,46H,23H('',第二个字符串开始),46H,41H,30H,2EH,34H,46H,41H,
30H,46H,41H,30H,2EH,34H,3DH,30H,2AH('*'),32H,31H,ODH,OAH,55H
结果为:23H,46H,41H,30H,2EH,34H,3DH,31H,2AH('*'),32H,31H(校验正确,该字符串原样保持),
ODH,OAH,21H,21H,21H,21H,21H,21H,21H,21H,21H,21H,21H,21H,21H(校验错,整个字符串用字符“!”代替)
部分程序已给出,其中原始数据由过程LOAD从文件INPUT.DAT中读入SOURCE开始的内存单元中。运算结果要求从 RESULT开始存放,由过程SAVE保存到文件OUTPUT.DAT中。
请填空BEGIN和END之间已给出的源程序使其完整,空白已用横线标出,每个空白一般只需一条指令,但采用功能相当的多条指令亦可,或删除BEGIN和END之间原有的代码并自行编程来完成所要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生可执行文件,最终运行程序产生结果。调试中若发现整个程序中存在错误之处,请加以修改。
【试题程序】
EXTRN LOAD:FAR, SAVE:FAR
N EQU 26
STAC SEGMENT STACK
DB 128 DUP ()
STAC ENDS
DATA SEGMENT
SOURCE DB N+4 DUP()
RESULT DB N DUP(0)
HH DB 2 DUP(0)
NAME0 DB 'INPUT.DAT',0
NAME1 DB 'OUTPUT.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA, SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX, SOURCE ; 数据区起始地址
LEA SI,NAME0 ; 原始数据文件名
MOV CX, N+4 ; 字节数
CALL LOAD ; 从'INPUT. DAT' 中读取数据
;******** BEGIN ********
MOV SI,0
MOV DI,0
MOV BX,2 ; 两个ASCII 字符串
REPEAT: MOV AH,0
SEARCH: MOV AL,SOURCE[SI]
INC SI
CMP AL,''
(1) SEARCH
MOV RESULT[DI],AL
INC DI
SEARCH1: MOV AL,SOURCE[SI]
INC SI
CMP AL, (2)
JE ASCII
&nb
1 TBARA DB 30H,31H,32H,33H,34,35H,36H,37H DB 38H,39H,41H,42H,43H,44H,45H,46H
2 MOV BX,OFFSET TABBA
3 MOV AL,0CH
4 ()
A.ADD AL,30H
B.XOR AL,FFH
C.ADD AL,40H
D.XLAT TABBA
若(SS)=2000H,(BP)=3000H,(SI)=4000H,指令MOV AL,[BP+SI+10H]中源操作数的物理地址是【 】H。
假设VAR为变量,指令MOV BX,OFFSET VAR中源操作数的寻址方式是()。
A.直接寻址
B.间接寻址
C.立即寻址
D.存储器寻址
●若CPU要执行的指令为:MOV R1,#45(即将数值45传送到寄存器Rl中),则该指令中采用的寻址方式为(4)。
(4)A.直接寻址和立即寻址
B.寄存器寻址和立即寻址
C.相对寻址和直接寻址
D.寄存器间接寻址和直接寻址
在80386以上的微处理器指令系统中,以下指令的源操作数的寻址方式是()。 MOV AX,[ARR+BX+DI]
A.基址变址寻址
B.相对基址变址寻址
C.寄存器间接寻址
D.寄存器相对寻址(变址寻址)
●若CPU要执行的指令为:MOV R1,#45(即将数值45传送到寄存器R1中),则该指令中采用的寻址方式为(4)。
(4)A.直接寻址和立即寻址
B.寄存器寻址和立即寻址
C.相对寻址和直接寻址
D.寄存器间接寻址和直接寻址
在80386以上的微处理器指令系统中,以下指令的源操作数的寻址方式是()。 MOV AX,[BX][SI]
A.基址变址寻址
B.寄存器寻址
C.寄存器间接寻址
D.寄存器相对寻址(变址寻址)
指令“MOV AX, ES: [BX] [SI]”的源操作数的物理地址是______。
A.16d X(DS)+(BX)+(SI)
B.16d X(ES)+(BX)+(SI)
C.16d X(SS)+(BX)+(SI)
D.16d X(CS)+(BX)+(SI)
在32位微处理器指令系统中,MOV AX,[EBX+2*ECX]指令的源操作数寻址方是()。
A.寄存器寻址
B.寄存器比例寻址
C.寄存器间接寻址
D.存储器直接寻址