BUFFER DB 10 DUP();BUFFER存放8个不确定数
augend DB 2 DUP() ;被加数
addend DB 2 DUP() ;加数
msg1 DB 0DH,0AH,'请输入被加数: $'
msg2 DB 0DH,0AH,'请输入加数: $'
msg3 DB 0DH,0AH,'结果: $';msg3存放结果
;0DH和0AH分别是回车和换行的ASCII码,
;'$'是DOS功能调用INT 21H中9号功能要求的要显示字符串的结束标志
CODE
START: MOV AX,@DATA
MOV DS,AX
MOV ES,AX
CLD ;方向标志位清零 ;CLD与STD是用来 *** 作方向标志位DF(Direction Flag)。
;CLD使DF复位,即DF=0,STD使DF置位,即DF=1用于串 *** 作指令中
NOP ;空 *** 作 ;NOP指令只使程序计数器PC加1,所以占用一个机器周期
;其目的为保证写、读之间有个稳定时间
MOV AH,00H
MOV AL,03H
INT 10H ;清屏
START1: MOV AH,09H ;9号调用DX指向被加数的首地址,输出提示信息
LEA DX,msg1 ;将源 *** 作数给出的有效地址传送到指定的的寄存器中
INT 21H
LEA DI,augend ;DI->augend的首地址
MOV CX,4 ;按键次数
CALL GetBCDKey ;得到双字节十进制数(被加数)
JNB START2 ;没有输入任何数字,结束 CF=0
MOV AH,09H ;9号调用DX指向加数的首地址
LEA DX,msg2 ;将源 *** 作数给出的有效地址传送到指定的的寄存器中
INT 21H
LEA DI,addend ;di指向加数
MOV CX,4 ;按键次数
CALL GetBCDKey ;得到双字节十进制数(加数)
JNB START2 ;没有输入任何数字,结束
MOV AL,augend ;被加数的低8位送al
ADD AL,addend ;al与加数的低位相加的结果送al
DAA ;BCD算术运算调整,转换为压缩型BCD
XCHG AL,AH ;高位与低位互换
MOV AL,augend + 1
ADC AL,addend + 1 ;高位
DAA
XCHG AL,AH
MOV BL,0
ADC BL,0 ;进位 bl存放的是进位 bl和ax相加是最后的结果
STD ;方向标志置1
LEA DI,BUFFER+4 ;存放显示结果
CALL B1toB2 ;低位
MOV AL,AH
CALL B1toB2 ;高位
MOV AL,BL
OR AL,30H ;转换成数字
STOSB ;存数
LEA SI,BUFFER
MOV CX,5
CALL BlackDisplay ;将高位0消隐
MOV AH,09H
LEA DX,msg3 ;9号调用DX指向结果的首地址
INT 21H
MOV AH,09H
LEA DX,BUFFER ;9号调用DX指向BUFFER的首地址
INT 21H
JMP START1 ;跳转到START1
START2: MOV AH,4CH ;结束程序
INT 21H
; JMP $
;将一个字节压缩BCD码转换成二个字节数字
B1toB2 PROC NEAR ;段内
PUSH AX ;ax存放的是相加后的结果
AND AL,0FH ;高四位置0
OR AL,30H ;加30H
STOSB ;存数 个位 百位
POP AX
AND AL,0F0H ;低四位置0
ROR AL,4 ;循环右移4位
OR AL,30H ;加30H
STOSB ;存数 十位 千位
RET
B1toB2 ENDP
BlackDisplay PROC NEAR
CLD ;方向标志清零
MOV DI,SI ;si送给di si指向buff的第一个缓冲区 增量变化
BlackDisplay1: LODSB ;将高位0消隐,取串
CMP AL,'0'
JNZ Exit ;若al不等于0跳转EXIT
LOOP BlackDisplay1 ;否则cx不为0一直循环 cx次
INC CX ;cx加1
Exit: DEC SI ;si前移
REP MOVSB ;重复传送字节
MOV AL,'$' ;把$符送al
STOSB ;存数
RET
BlackDisplay ENDP
GetBCDKey PROC NEAR
LEA SI,BUFFER
MOV AL,4 ;把4写入到buff
MOV [SI],AL ;是内存单元
MOV DX,SI
MOV AH,0AH ;dx指向缓冲区
MOV AL,02H ;0:任意字符 1:16进制数 2:10进制数,10进制数输入
INT 21H
GetBCDKey1: LODSB ;ds:si->al
AND AL,0FH ;高4位清零
CMP CX,1 ;
JE GetBCDKey2
DEC CX ;进数位-1
MOV AH,AL
LODSB
AND AL,0FH
SHL AL,4 ;逻辑左移4位
OR AL,AH ;
GetBCDKey2: CLD
STOSB ;存串指令
STD
LOOP GetBCDKey1 ;cx=2 原先为4 上面减了一次一 loop再减一所以等于2
MOV CL,[BUFFER]
SUB CL,[BUFFER+1]
SHR CL,1 ;逻辑右移1位
MOV AL,0
CLD
REP STOSB ;重复存数
STC ;进位标志位置1
RET
GetBCDKey3: CLC ;进位标志位清零cf=0
RET ;返回
GetBCDKey ENDP
微机原理又名:微型计算机原理。是一门计算机专业的必修课程。一般到毕业的时候都会有清考,到时候一般学校还会组织补习班,只要清考通过,就可以拿到毕业证。
《微机原理》是一门专业基础课程,它的主要内容包括微型计算机体系结构、8086微处理器和指令系统、汇编语言设计以及微型计算机各个组成部分介绍等内容。
要求考生对微机原理中的基本概念有较深入的了解,能够系统地掌握微型计算机的结构、8086微处理器和指令系统、汇编语言程序设计方法、微机系统的接口电路设计及编程方法等,并具有综合运用所学知识分析问题和解决问题的能力。
微机原理实验工具:
1、微机原理与接口技术实验箱。
2、Masm50汇编调试程序。
3、emu8086仿真软件。
4、北斗一号微机原理虚拟实验系统。
存储结构:
1、半导体存储器的种类。
2、读写存储器(RAM)。
3、只读存储器(ROM)。
4、PC/XT的存储结构。
*** 作时序:
1、总线 *** 作的概念。
2、8086的总线。
3、8086的典型时序。
4、计数器和定时器电路Intel 8253。
它们的主要差异有:\x0d\1、 子程序调用一定是程序员在编写程序时事先安排好的,是可知的,而中断是由中断源根据自身的需要产生的,是不可预见的(用指令INT引起的中断除外) \x0d\2、 子程序调用是用CALL指令来实现的,但没有调用中断的指令,只有发出中断请求的事件(指令INT是发出内部中断信号,而不要理解为调用中断服务程序); \x0d\3、 子程序的返回指令是RET,而中断服务程序的返回指令是IRET/IRETD。 \x0d\4、 在通常情况下,子程序是由应用程序开发者编写的,而中断服务程序是由系统软件设计者编写的。 \x0d\5、中断方式具有实时性,其可以在函数中的任意位置产生。而子程序调用是编程着写的在程序的特定位置其特定功能的函数。
以上就是关于合肥学院微机实验4(子程序调用实验代码及解析)全部的内容,包括:合肥学院微机实验4(子程序调用实验代码及解析)、微机原理、微机原理里面中断方式和子程序调用的区别是什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)