数据传送及两个多位十进制数相加

深 圳 大 学 实 验 报 告

课程名称: 微机原理及应用实验

实验项目名称: 数据传送及两个多位十进制数相加

学院: 物理科学与技术学院

专业: 应用物理

指导教师: 李雄军

报告人: 学号: 班级:

实验时间:

实验报告提交时间:

一、实验目的 (1)继续熟练掌握在PC 机上建立、汇编、链接、调试和运行8088汇编语言程序的过程;

(2)学习数据传送和算术运算指令的用法;

(3)掌握子程序设计方法;

(4)掌握宏汇编设计方法。

二、实验内容

将两个多位十进制数(若为16位二进制表示的无符号数)相加。要求被加数均以ASCII 码形式各自顺序存放在以DATAl 和DATA2为首的5个内存单元中(低位在前) ,结果送回DATAl 处。

三、程序流程图

算法说明:以42136与12547相加为例,首先将两个数中的每一位都以ASCII码存入相应的内存单元,然后将每一位数都减去30H,并将被加数和加数相对应位相加(要考虑低位向高位的进位),存入相应的被加数存储单元中,最后将该单元中的每一位数转换成相应的ASCII码,调用DOS系统的显示字符指令,显示两数相加的结果。

四、源程序代码

DATA SEGMENT ; 数据段

DATA1 DB 31H,33H,31H,31H,33H ; 定义DATA1为被加数

DATA2 DB 33H,33H,33H,32H,33H ; 定义DATA2为加数

DATA ENDS ; STACK SEGMENT STACK ; 堆栈段

STA DB 64 DUP(0) ;

SP_TOP DB 0 ; 定义SP_TOP单元数值为0

STACK ENDS ; 堆栈段结束

CODE SEGMENT ; 代码段

ASSUME CS:CODE , DS:DATA , ES:DATA , SS:STACK ; 指定段寄存器

CFLF MACRO ; 显示回车换行功能用宏定义CFLF 实现,放在代码段最前面

MOV DL,0DH ; 回车(0DH 为回车的ASCII 码 ) MOV AH,02H ; 送DOS 的中断调用功能号 INT 21H ; DOS 的中断调用 MOV DL,0AH ; 用DOS 功能调用实现换行,0AH 为换行的ASCII 码 MOV AH,02H ; 显示字符到屏幕上

INT 21H ;DOS 中断调用

CFLF ENDM ; 结束宏定义

START: MOV AX, DATA ; 设置数据段

MOV DS, AX ; 数据段初始化

MOV AX, STACK ; 设置堆栈段

MOV SS, AX ; 堆栈段初始化

MOV AL,SP_TOP ; 设置栈顶指针

MOV SI, OFFSET DATA1 ; 显示被加数,并回车换行

MOV BX,05 ;

CALL DISPL ; 显示被加数,DISPL 为显示子程序

CFLF ; 回车、换行宏调用

MOV SI, OFFSET DATA2 ; 显示加数

MOV BX,05 ; 设置计数器赋值05

CALL DISPL ; 显示加数 CFLF ; 回车换行

CALL ADDA ; 调用加法运算子程序

MOV SI,OFFSET DATA1 ; 把DATA1的偏移量地址赋给SI MOV BX,05 ;

CALL DISPL ; 显示结果

CFLF ; 回车、换行

MOV AX,4C00H ; 返回DOS

INT 21H ;DOS 中断调用

DISPL PROC NEAR ;DISP 为字符串显示子程序

DSL: MOV AH,02 ; 送显示功能号 MOV DL,[SI+BX-1] ; 显示字符串中一字符 INT 21H

DEC BX

JNZ DSL

RET

DISPL ENDP

ADDA PROC NEAR

MOV SI, OFFSET DATA1

MOV DI, OFFSET DATA2

MOV AH,0

MOV CX,05

AD1: MOV AL,[SI]

SUB AL,30H

MOV BL,[DI]

SUB BL,30H ADD AL, BL

ADD AL, AH

MOV AH,0

AAA

MOV [SI],AL

INC INC DI SI DEC CX JNZ AD1

MOV MOV BX,05 SI, OFFSET DATA1

AD2: ADD [SI+BX-1],30H

DEC BX

JNE AD2

RET

ADDA ENDP

CODE ENDS

END START

;DOS INT 21 功能调用 ;BX-1,修改偏移量 ; 若BX 不等于0, 跳转到DSL ; 返回 ; 子程序结束 ; 加法子程序 ; 取被加数的偏移地址 ; 取加数偏移地址 ; 进位清零 ; 设置循环次数 ; 取被加数偏移量地址内容 ; ; 取加数偏移量地址内容 ; ; ; 加上进位 ; 进位清零 ; BCD十进制转换 ; 存回DATA1的相应单元 ; ; ; ;CX 未减到0继续跳转,重新执行次位相加 ; ; ; 相加之后转化为相应的ASCII 码 ; 改变循环次数 ;BX 未减到0则跳转至AD2 ; 返回 ; 加法子程序结束 ; 代码段与程序结束 ; 程序结束

五、实验结果

1. 编译、连接生成可执行文件,分别在debug和Emu8086下调试该可执行文件 在debug 下运行:

在emu8086下运行:

2. 给出程序运行时的各段地址(CS=?,DS=?SS=?ES=?)及两个子程序入口的IP.

DISPL:IP=0054 ADDA:IP=0037

CS=F400,DS=0710,SS=0711,ES=0700

3. 试改变加数和被加数,如何从内存中观察结果的变化?

4. 总结子程序格式及其调用方法;结合本程序说明宏调用与子程序的区别。

子程序是程序的一部分,可以被程序调用,当过程中的指令执行完后,返回程序调用点,调用过程的指令是CALL (CALL 过程名),从过程返回的指令为RET (在子程序调用快要完成之时,加上RET. 即在 过程名 ENDP指令之前加上RET 指令)。 区别:1). 在汇编后产生的.obj 文件中,子程序定义依然存在,而宏定义却不复存在。

2). 子程序调用是在执行时通过CALL 指令完成的,而宏调用是在汇编时进行宏展开,被相应宏体所取代。

3). 将多次调用的一段代码定义为宏指令,与使用子程序相比,其执行速度要快(因为过程需要调用和返回),但目标代码长。

4). 宏指令的参数是在汇编时进行形实替换的,而子程序的参数是在执行时通过寄存器或堆栈等方式传递的。

六、实验总结

这次实验能顺利开始进行最重要的还是依赖于预习,首先在课下想好该使用什么算法,然后画出程序流程图才可以很好地进行写代码,按步骤地依照流程图,就不会出现写程序写到一半卡住了。这次的实验对于偏移量的理解要求较强,因为对于被加数与加数各个数位相加而且要求两者都显示出来。而对子程序和宏调用也要预习,了解它们的定义、格式和区别。还有对源代码要清楚的区分开,比如指令ADC 与ADD 使用错误,会导致了进位的出错。

七、思考题

1. 在键盘上输入一个字符或数字,要求:对十六进制数字(由0-9,A ~F 或a~f组成),显示该数字的十进制值;当输入值为Q 时结束程序,对其他输入提示输入不合法。画出程序流程图并请写出完整程序代码。

答: 源程序代码:

DATA SEGMENT STR DB 'PLEASE INPUT A NUMBER(H):','$'

WRONG DB 'SORRY!THE NUMBER IS ILLEGAL!','$'

QUIT DB 'THE PROGRAM HAS EXITED!','$'

DATA ENDS

STACK SEGMENT STACK ;堆栈段

STA DB 64 DUP(0)

SP_TOP DB 0

STACK ENDS

CODE SEGMENT ; 代码段

ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK ;指定段寄存器

START:

MOV AX,DATA

MOV DS,AX

MOV AX,STACK

MOV SS,AX

LP: LEA DX,STR

MOV AH,09H

INT 21H

MOV AH,01H

INT 21H

CALL JUDGE

CMP AL,51H

JNZ LP1

MOV AH,4CH

INT 21H

LP1: CALL CRLF

JMP LP

CRLF PROC NEAR

MOV DL,0DH

MOV AH,02H INT 21H MOV DL,0AH MOV AH,02H INT 21H

POP AX

RET CRLF ENDP

JUDGE PROC NEAR

CMP AL,51H

JZ A4

CMP AL,30H

JB A1

CMP AL,3AH

JB A3

CMP AL,41H

JB A1

CMP AL,47H

JB A2

A1: LEA DX,WRONG

MOV AH,09H

INT 21H

JMP RETURN

A2: SUB AL,11H

MOV BL,AL

MOV DL,31H

MOV AH,02H

INT 21H

MOV AL,BL

A3: MOV DL,AL

MOV AH,02H INT 21H

JMP RETURN A4: LEA DX,QUIT MOV AH,09H INT 21H MOV AL,51H RETURN: RET

JUDGE ENDP

CODE ENDS END START

深 圳 大 学 实 验 报 告

课程名称: 微机原理及应用实验

实验项目名称: 数据传送及两个多位十进制数相加

学院: 物理科学与技术学院

专业: 应用物理

指导教师: 李雄军

报告人: 学号: 班级:

实验时间:

实验报告提交时间:

一、实验目的 (1)继续熟练掌握在PC 机上建立、汇编、链接、调试和运行8088汇编语言程序的过程;

(2)学习数据传送和算术运算指令的用法;

(3)掌握子程序设计方法;

(4)掌握宏汇编设计方法。

二、实验内容

将两个多位十进制数(若为16位二进制表示的无符号数)相加。要求被加数均以ASCII 码形式各自顺序存放在以DATAl 和DATA2为首的5个内存单元中(低位在前) ,结果送回DATAl 处。

三、程序流程图

算法说明:以42136与12547相加为例,首先将两个数中的每一位都以ASCII码存入相应的内存单元,然后将每一位数都减去30H,并将被加数和加数相对应位相加(要考虑低位向高位的进位),存入相应的被加数存储单元中,最后将该单元中的每一位数转换成相应的ASCII码,调用DOS系统的显示字符指令,显示两数相加的结果。

四、源程序代码

DATA SEGMENT ; 数据段

DATA1 DB 31H,33H,31H,31H,33H ; 定义DATA1为被加数

DATA2 DB 33H,33H,33H,32H,33H ; 定义DATA2为加数

DATA ENDS ; STACK SEGMENT STACK ; 堆栈段

STA DB 64 DUP(0) ;

SP_TOP DB 0 ; 定义SP_TOP单元数值为0

STACK ENDS ; 堆栈段结束

CODE SEGMENT ; 代码段

ASSUME CS:CODE , DS:DATA , ES:DATA , SS:STACK ; 指定段寄存器

CFLF MACRO ; 显示回车换行功能用宏定义CFLF 实现,放在代码段最前面

MOV DL,0DH ; 回车(0DH 为回车的ASCII 码 ) MOV AH,02H ; 送DOS 的中断调用功能号 INT 21H ; DOS 的中断调用 MOV DL,0AH ; 用DOS 功能调用实现换行,0AH 为换行的ASCII 码 MOV AH,02H ; 显示字符到屏幕上

INT 21H ;DOS 中断调用

CFLF ENDM ; 结束宏定义

START: MOV AX, DATA ; 设置数据段

MOV DS, AX ; 数据段初始化

MOV AX, STACK ; 设置堆栈段

MOV SS, AX ; 堆栈段初始化

MOV AL,SP_TOP ; 设置栈顶指针

MOV SI, OFFSET DATA1 ; 显示被加数,并回车换行

MOV BX,05 ;

CALL DISPL ; 显示被加数,DISPL 为显示子程序

CFLF ; 回车、换行宏调用

MOV SI, OFFSET DATA2 ; 显示加数

MOV BX,05 ; 设置计数器赋值05

CALL DISPL ; 显示加数 CFLF ; 回车换行

CALL ADDA ; 调用加法运算子程序

MOV SI,OFFSET DATA1 ; 把DATA1的偏移量地址赋给SI MOV BX,05 ;

CALL DISPL ; 显示结果

CFLF ; 回车、换行

MOV AX,4C00H ; 返回DOS

INT 21H ;DOS 中断调用

DISPL PROC NEAR ;DISP 为字符串显示子程序

DSL: MOV AH,02 ; 送显示功能号 MOV DL,[SI+BX-1] ; 显示字符串中一字符 INT 21H

DEC BX

JNZ DSL

RET

DISPL ENDP

ADDA PROC NEAR

MOV SI, OFFSET DATA1

MOV DI, OFFSET DATA2

MOV AH,0

MOV CX,05

AD1: MOV AL,[SI]

SUB AL,30H

MOV BL,[DI]

SUB BL,30H ADD AL, BL

ADD AL, AH

MOV AH,0

AAA

MOV [SI],AL

INC INC DI SI DEC CX JNZ AD1

MOV MOV BX,05 SI, OFFSET DATA1

AD2: ADD [SI+BX-1],30H

DEC BX

JNE AD2

RET

ADDA ENDP

CODE ENDS

END START

;DOS INT 21 功能调用 ;BX-1,修改偏移量 ; 若BX 不等于0, 跳转到DSL ; 返回 ; 子程序结束 ; 加法子程序 ; 取被加数的偏移地址 ; 取加数偏移地址 ; 进位清零 ; 设置循环次数 ; 取被加数偏移量地址内容 ; ; 取加数偏移量地址内容 ; ; ; 加上进位 ; 进位清零 ; BCD十进制转换 ; 存回DATA1的相应单元 ; ; ; ;CX 未减到0继续跳转,重新执行次位相加 ; ; ; 相加之后转化为相应的ASCII 码 ; 改变循环次数 ;BX 未减到0则跳转至AD2 ; 返回 ; 加法子程序结束 ; 代码段与程序结束 ; 程序结束

五、实验结果

1. 编译、连接生成可执行文件,分别在debug和Emu8086下调试该可执行文件 在debug 下运行:

在emu8086下运行:

2. 给出程序运行时的各段地址(CS=?,DS=?SS=?ES=?)及两个子程序入口的IP.

DISPL:IP=0054 ADDA:IP=0037

CS=F400,DS=0710,SS=0711,ES=0700

3. 试改变加数和被加数,如何从内存中观察结果的变化?

4. 总结子程序格式及其调用方法;结合本程序说明宏调用与子程序的区别。

子程序是程序的一部分,可以被程序调用,当过程中的指令执行完后,返回程序调用点,调用过程的指令是CALL (CALL 过程名),从过程返回的指令为RET (在子程序调用快要完成之时,加上RET. 即在 过程名 ENDP指令之前加上RET 指令)。 区别:1). 在汇编后产生的.obj 文件中,子程序定义依然存在,而宏定义却不复存在。

2). 子程序调用是在执行时通过CALL 指令完成的,而宏调用是在汇编时进行宏展开,被相应宏体所取代。

3). 将多次调用的一段代码定义为宏指令,与使用子程序相比,其执行速度要快(因为过程需要调用和返回),但目标代码长。

4). 宏指令的参数是在汇编时进行形实替换的,而子程序的参数是在执行时通过寄存器或堆栈等方式传递的。

六、实验总结

这次实验能顺利开始进行最重要的还是依赖于预习,首先在课下想好该使用什么算法,然后画出程序流程图才可以很好地进行写代码,按步骤地依照流程图,就不会出现写程序写到一半卡住了。这次的实验对于偏移量的理解要求较强,因为对于被加数与加数各个数位相加而且要求两者都显示出来。而对子程序和宏调用也要预习,了解它们的定义、格式和区别。还有对源代码要清楚的区分开,比如指令ADC 与ADD 使用错误,会导致了进位的出错。

七、思考题

1. 在键盘上输入一个字符或数字,要求:对十六进制数字(由0-9,A ~F 或a~f组成),显示该数字的十进制值;当输入值为Q 时结束程序,对其他输入提示输入不合法。画出程序流程图并请写出完整程序代码。

答: 源程序代码:

DATA SEGMENT STR DB 'PLEASE INPUT A NUMBER(H):','$'

WRONG DB 'SORRY!THE NUMBER IS ILLEGAL!','$'

QUIT DB 'THE PROGRAM HAS EXITED!','$'

DATA ENDS

STACK SEGMENT STACK ;堆栈段

STA DB 64 DUP(0)

SP_TOP DB 0

STACK ENDS

CODE SEGMENT ; 代码段

ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK ;指定段寄存器

START:

MOV AX,DATA

MOV DS,AX

MOV AX,STACK

MOV SS,AX

LP: LEA DX,STR

MOV AH,09H

INT 21H

MOV AH,01H

INT 21H

CALL JUDGE

CMP AL,51H

JNZ LP1

MOV AH,4CH

INT 21H

LP1: CALL CRLF

JMP LP

CRLF PROC NEAR

MOV DL,0DH

MOV AH,02H INT 21H MOV DL,0AH MOV AH,02H INT 21H

POP AX

RET CRLF ENDP

JUDGE PROC NEAR

CMP AL,51H

JZ A4

CMP AL,30H

JB A1

CMP AL,3AH

JB A3

CMP AL,41H

JB A1

CMP AL,47H

JB A2

A1: LEA DX,WRONG

MOV AH,09H

INT 21H

JMP RETURN

A2: SUB AL,11H

MOV BL,AL

MOV DL,31H

MOV AH,02H

INT 21H

MOV AL,BL

A3: MOV DL,AL

MOV AH,02H INT 21H

JMP RETURN A4: LEA DX,QUIT MOV AH,09H INT 21H MOV AL,51H RETURN: RET

JUDGE ENDP

CODE ENDS END START


相关文章

  • 微机原理与接口技术汇编语言指令详解吐血版
  • 第一讲 第三章 指令系统--寻址方式 回顾: 8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过 程. 重点和纲要:指令系统--寻址方式.有关寻址的概念:6种基本的寻址方式及 有效地址的计算. 讲授内容: 3. ...查看


  • 计算机组成原理知识点总结--详细版
  • 计算机组成原理2009年12月期末考试复习大纲 第一章 1. 计算机软件的分类. P11 计算机软件一般分为两大类:一类叫系统程序,一类叫应用程序. 2. 源程序转换到目标程序的方法. P12 源程序是用算法语言编写的程序. 目标程序(目的 ...查看


  • 广播电视大学[计算机组成形成性考核册]形考作业答案
  • 计算机组成原理A 形考作业一(参考答案) 一.选择题: 1.机器数_____中,零的表示形式是唯一的. A .原码 B .补码 C .移码 D .反码 答案:B ,C 2.某计算机字长16位,采用补码定点小数表示,符号位为1位,数值位为15 ...查看


  • 微机原理课
  • 微机原理 课 1 讲 教 案 绪论 §1-1 计算机的发展概况及分类 §1-1-1 计算机的发展概况 1946年,第一台计算机在美国诞生,至今已有近60年的历史.60年来,计算机经历了 迅猛的发展,得到了广泛的普及,对整个社会的进步和科学的 ...查看


  • 汇编语言详解
  • 汇编语言详解 汇编语言(Assembly Language)是面向机器的程序设计语言. 汇编语言中,用助记符(Memoni)代替操作码,用地址符号(Symbol)或标号(Label)代替地址码.这样用符号代替机器语言的二进制码,就把机器语言 ...查看


  • (计算机原理会考试题库)
  • <计算机组成与工作原理>试题库 教材 <计算机组成与工作原理> 电子工业出版社 刘晓川 主编 一.选择题 [0102A] 1.计算机直接存储器存取传送方式就是( ). A .程序查询方式 B.中断处理方式 C .DM ...查看


  • 计算机组成原理课后答案(第三版·白中英)
  • 计算机组成原理各章答案(白中英·第三版) 第一章答案 1. 比较数字计算机和模拟计算机的特点. 解:模拟计算机的特点:数值由连续量来表示,运算过程是连续的: 数字计算机的特点:数值由数字量(离散量)来表示,运算按位进行. 两者主要区别见P1 ...查看


  • 汇编语言期末复习资料
  • 一.单项选择题(本大题共10小题,每小题3分,共30分)在每小题列出的四个备选项中只有一个是符合题目要求的,请将其代码填写在题后的括号内.错选.多选或未选均无分. 1.CPU要访问的某一存储单元的实际地址称(C) A. 段地址 B. 偏移地 ...查看


  • 计算机中信息的表示方法
  • 计算机基础知识:第二章计算机中的信息表示1 第二章 计算机中的信息表示 2.1 进位计数制 2.1.1数制的概念 什么是数制?数制是用一组固定的数字和一套统一的规则来表示数目的方法. 按照进位方式计数的数制叫进位计数制.十进制即逢十进一,生 ...查看


热门内容