【实验目的】
1、掌握程序设计中的3种基本结构(顺序结构、选择程序、循环程序)。
2、熟练使用汇编语言的指令:数据传送类指令、数据运算类指令、逻辑判断类指令与转移指令、循环指令等。
3、初步了解系统功能调用的使用方法,尝试使用01H号功能调用进行字符输入的方法及使用02H号功能调用进行字符输出(显示)的方法。
【实验内容】
1.编写程序,实现从键盘输入的小写字母用大写字母显示出来,对输入须合法性检查,如果用户输入不合法,则显示提示语句:
please input lower case letters!
DATA SEGMENT
STR DB 'Please input lower case letters!$'
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START:
MOV AX,DATA
MOV DS,AX
MOV AH,1
INT 21H
CMP AL,61H
JL TIP
CMP AL,7AH
JG TIP
SUB AL,20H
JMP PRINT
TIP:
MOV AH,9
LEA DX,STR
INT 21H
PRINT:
MOV DL,AL
MOV AH,2
INT 21H
MOV AH,4CH
INT 21H
CODE ENDS
END START
2.编写程序,根据键盘输入的一位数字(1~8),使程序转移到8个不同的分支中去,以显示键盘输入的数字。注意:在数据段定义分支地址表。
DATA SEGMENT
BRANCH DW R1, R2,R3,R4,R5,R6,R7,R8
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START:
MOV AX,DATA
MOV DS,AX
MOV AH,7
INT 21H
CMP AL,31H
JL EXIT
CMP AL,39H
JG EXIT
MOV BL,AL
SUB BL,31H
SHL BL,1
MOV BH,0
JMP BRANCH[BX]
R1:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R2:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R3:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R4:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R5:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R6:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R7:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
R8:
MOV DL,AL
MOV AH,2
INT 21H
JMP EXIT
EXIT:
MOV AH,4CH
INT 21H
CODE ENDS
END START
3.编写程序,定义一个存储5个字类型数字的数组array.程序将正数存在正数数组str1中,负数存储在负数数组str2中,并统计正数的个数然后输出
DATA SEGMENT
ARRAY DW 1,2,-1,-3,9
STR1 DW 5 DUP(?)
STR2 DW 5 DUP(?)
POSITIVECOUNT DW 0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START:
MOV AX,DATA
MOV DS,AX
LEA SI,ARRAY
LEA DI,STR1
LEA BX,STR2
MOV CX,5
LK:
CMP CX,0
JE PRINT
MOV AL,[SI]
TEST AL,AL
JS NEGATIVE
MOV [DI],AL
ADD DI,2
INC POSITIVECOUNT
JMP NEXT
NEGATIVE:
MOV [BX],AL
ADD BX,2
NEXT:
ADD SI,2
LOOP LK
PRINT:
ADD POSITIVECOUNT,30H
MOV AH,2
MOV DL,POSITIVECOUNT
INT 21H
MOV AH,4CH
INT 21H
CODE ENDS
END START
【小结或讨论】
本次实验第一个实验中用到了用到了上课说的知识,小写转大写,即大小写之间差20H,进行加减法得到对应的ASCII即可。本题和课上说的唯一的不同之处在于有一个合法性判断,采用字符串定义在数据段,比较有误后输入即可。
第二个实验也是课本上的多分支,采用07号功能不回显输入,然后通过将AL传到BL中进行-30H得到对应数字,并且左移得到对应下标,左移是由于本题采用字存储,每个字占两个字节。其余就很简单了,对应下标到对应操作即可
第三题是本实验难点,首先定义了三个数组以及一个变量POSITIVECOUNT记录正数个数,然后通过CX不断减减并在此过程中不断进行正负比较,如果为正放入STR1并且INC POSITIVECOUNT,否则放入STR2,最后将POSITIVECOUNT输出。在这个过程中我在最后结果输出时发现内存中值为正确的,但是输出却为爱心,经过查阅发现出现了输出值而不是数字对应ASCII的问题,直接POSITIVECOUNT+30H输出结果就会正确了。