汇编语言课程设计报告-实现加减乘除四则运算的计算器_第1页
汇编语言课程设计报告-实现加减乘除四则运算的计算器_第2页
汇编语言课程设计报告-实现加减乘除四则运算的计算器_第3页
汇编语言课程设计报告-实现加减乘除四则运算的计算器_第4页
汇编语言课程设计报告-实现加减乘除四则运算的计算器_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、- -.- - 可修编-. - - - 可修编-汇编语言课程设计报告( 2011 - 2012 年度第 2 学期)实现加减乘除四则运算的计算器专业计算机科学与技术学生班级*指导教师完成日期- -. - -目 录 TOC o 1-5 h z u HYPERLINK l _Toc328209478目录 PAGEREF _Toc328209478 h 2HYPERLINK l _Toc3282094791 概述 PAGEREF _Toc328209479 h 1HYPERLINK l _Toc3282094801.1 设计目的 PAGEREF _Toc328209480 h 1HYPERLINK l

2、 _Toc3282094811.2 设计容 PAGEREF _Toc328209481 h 1HYPERLINK l _Toc3282094822 系统需求分析 PAGEREF _Toc328209482 h1HYPERLINK l _Toc3282094832.1 系统目标 PAGEREF _Toc328209483 h 1HYPERLINK l _Toc3282094842.2 主体功能 PAGEREF _Toc328209484 h 1HYPERLINK l _Toc3282094852.3 开发环境 PAGEREF _Toc328209485 h 1HYPERLINK l _Toc32

3、82094863 系统概要设计 PAGEREF _Toc328209486 h 2HYPERLINK l _Toc3282094873.1 系统的功能模块划分 PAGEREF _Toc328209487 h 2HYPERLINK l _Toc3282094883.2 系统流程图 PAGEREF _Toc328209488 h 3HYPERLINK l _Toc3282094894系统详细设计 PAGEREF _Toc328209489 h 3HYPERLINK l _Toc3282094905测试 PAGEREF _Toc328209490 h 4HYPERLINK l _Toc3282094

4、915.1 测试方案 PAGEREF _Toc328209491 h 4HYPERLINK l _Toc3282094925.2 测试结果 PAGEREF _Toc328209492 h 4HYPERLINK l _Toc3282094936 小结 PAGEREF _Toc328209493 h 5HYPERLINK l _Toc328209494参考文献 PAGEREF _Toc328209494 h 6HYPERLINK l _Toc328209495附录 PAGEREF _Toc328209495 h 7HYPERLINK l _Toc328209496附录源程序清单 PAGEREF _

5、Toc328209496 h 7. 实现加减乘除四则运算的计算器1 概 述1.1 设计目的本课程设计是在学完教学大纲规定的全部容、完成所有实践环节的根底上,旨在深化学生学习的汇编语言课程根本知识,进一步掌握汇编语言程序设计方法,提高分析问题、解决问题的综合应用能力。1.2 设计容能实现加、减、乘、除的计算;该程序承受的是16进制数;执行时,需要在文件名后直接跟上计算表达式,如在命令提示符下执行结果如下:c:tasmjs 3+252 系统需求分析2.1 系统目标本次汇编语言课程设计的最终目的是要实现一个简单加减乘除四则运算的计算器,要求编写一个程序,每运行一次可执行程序,可以实现数的加减乘除四则

6、运算。比方,十进制数的加减乘除四则运算。我们曾经学习过两个具体数字进展加减法运算,但是对于简单计算器用汇编语言实现难点在于这两个要做运算的数是未知的,是由自己调用中断输入到屏幕上并要用程序存储起来的数,然后才能对这两个数进展运算,而且做的是加法运算、减法运算乘法运算还是除法运算也未可知,为此我们还要判断用户所输入的运算是四则运算中的哪一个运算。此外,运算过程中的进位或是借位,选择用什么样的方式进展输出,如何实现清屏等也是要解决的问题。2.2 主体功能系统分析主要包括设计的功能分析和系统的流程,功能分析放在首位,每一个软件都要能满足一定的功能才有使用价值。根据功能需求来创立应用程序。本设计的功能

7、如下: 1、输入2个数,先判断是加减运算还是乘除运算,再进展计算 2、判断符号是否为运算符 3、回车为换行符 4、用十进制或十六进制输出运算结果2.3 开发环境TASM5.0集成环境3 系统概要设计3.1 系统的功能模块划分此题目实现的模块图如图3-1所示四则运算计算器程序设计界面设置选择算法设置十进制转换设置图3-1 概要模块界面设置主要实现确定界面样式的功能,以菜单形式显示。选择算法设置 用于选择加、减、乘、除法来进展运算。十进制转换设置 应用十进制的转换算法来处理加、减、乘、除法四则运算。3.2 系统流程图输入选择键*=1“*=2“*=3“*=4“十六进制加法十六进制减法十六进制乘法十六

8、进制除法提示出错!*=0“?是是是否是否否否否*=Y/y “?否是是开 始结 束图3.2.1四则运算计算器执行过程流程图4系统详细设计4.1 界面设置 通过定义数据段,利用09H显示出功能列表。通过定义数据段,以字符串的形式输入每个提示信息,利用09H键盘输入并回显命令显示每一个功能提示,是计算器的功能列表有序清晰的显示在屏幕上。4.2 选择算法设置首先选择要进展的四则运算,假设选择1,则进展加法;假设选择2,则进展减法;假设选择3,则进展乘法;假设选择4,则进展除法。加法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入B*中,然后显示B* 和SI中的容相加存在B

9、*中。减法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入B*中,然后显示B* 和SI中的容相减存在B*中,然后用NEG来求反,即为第一个数减去第二个数的差,显示B*的容即为差。乘法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入B*中,把B*的值给A*,然后让A*乘以SI,然后再分别将D*,A*中的容赋给B*,接着依次显示D*,A*的容,即为积。除法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入B*中,将SI赋给A*作被除数,让B*作除数,得到的商存放在A*中,余数放在D*中,然后依次赋给B*,将其依

10、次显示即为商。4.3 十进制转换设置 要完成十进制转换成十六,一般采用除十六取余法来完成,其大致过程如下:将待转换的数除以16得到第一个商和余数,此第一个余数就是所求的十六进制数的各位,再用第一个商除以16,得到第二个商和余数,此第二个余数就是所求十六进制数的十位,重复这一过程直至商为0,此时的余数就是所求十六进制数的最高位。在存中分配一缓冲区,用来存放以上别离出来的使十进制数的每一位,然后再逐个转换成ASCII码,转换成ASCII码的过程很简单,就是给每个十六进制位加上30H即可,最后送显示器输出。5 测试5.1 测试方案对程序源代码进展功能调试和功能验证。程序代码运行成功后,分别检验测试其

11、加、减、乘、除功能,并对结果进展分析。当用户选择0时,输入Y或N决定是否退出程序。5.2 测试结果输入数字进展加减乘除运算,计算结果如下列图所示:图5.2.1 计算结果测试完毕后,退出程序,如下列图所示:图5.2.2 退出程序6 小结程序的主要功能是实现四则运算,整个程序中主要分为,输入算式,加法,减法,乘法,除法和以十进制显示结果这几个局部。本程序根本实现了四则运算的功能,但还没能实现带有括号的四则运算,还有在除法运算中不能运算较大的数,会产生溢出现象。一开场的时候自己编出来的程序有很多问题,尤其是在循环程序上,因此查阅了不少资料,也请教了好几个同学帮着修改,调试了好久才能正常运行。由于能力

12、有限,程序还是有不完美的地方。这次的综合实验让我对汇编有了更深刻的认识,对各种指令有了进一步的理解。. 参考文献1其明.汇编语言程序设计教程. :中国矿业大学, 2010.11. 附 录附录 源程序清单IN16 MACRO ;完成从键盘承受二个数并转换为十六制数,第一个数由SI指向,第二个数存放在B*中 LEA D*,PR ;D*指向PR换行CALL OUTPUT ;LEA D*,INPUT1 ;D*指向INPUT1,提示输入第一个数CALL OUTPUT CALL INPUT ;把输入的数存放在B*中LEA SI,RESULT ;SI指向RESULTMOV SI,B* ;把第一个十六制数存入

13、RESULT的第一个位置LEA D*,PR ;D*指向PR,换行CALL OUTPUT LEA D*,INPUT2 ;D*指向INPUT2,提示输入第一个数CALL OUTPUT CALL INPUT ;把输入的数存放在B*中ENDM ;宏完毕DATA SEGMENT ;数据段BUF DB ,0DH,0AHDB * WELE TO CALCULATOR SYSTEM *,0DH,0AHDB *1:ADD-2:SUB-3:MUL-4:DIV-0:QUIT*,0DH,0AHDB * 2011*6*21*,0DH,0AHDB 0DH,0AH,Please input the choose numbe

14、r:,$ INPUT1 DB Please input the first number *iao yu 4 wei:,$INPUT2 DB Please input the second number *iao yu 4 wei:,$RESULT DW “,“ ;存放键盘输入的两个十六制数WRO DB You input the number is wrong,please input again:,0DH,0AH,$; PR DB 0DH,0AH,$ ;将光标移到下一行起始位置PR1 DB A + B=$PR2 DB A - B=$PR3 DB A * B=$PR4 DB A / B=$P

15、R5 DB $PR6 DB Are you sure e*it“(Y/N)$ DATA ENDS ;数据段落定义完毕CODE SEGMENTMAIN PROC FAR ;主函数ASSUME CS:CODE ,DS:DATASTART:MOV A*,DATAMOV DS,A*LEA D*,BUF ;D*指向BUF换行CALL OUTPUT ;调用显示字符串函数换行SUB A*,A* ;A*清零CALL CHOOSE ;调用选择函数JMP START ;跳转到STARTRET MAIN ENDPINPUT PROC NEAR ;定义INPUT函数,就是将从键盘输入的数按原十六进制数存放在B*中MO

16、V B*,0 ;B*清零NEWCHAR:MOV AH,1 INT 21H ;承受键盘输入一个字符CMP AL,0DH ;输入的字符与回车比拟JE E*IT ;是回车就完毕 CMP AL,A ;与A比拟JAE H0 ;大于等于就跳转到H0 CMP AL,0 ;与0比拟JAE H1 ;大于等于就跳转到H1 H0:SUB AL,37H ;由于41-A=37,完成把字母字符转换成对应的十六进制数JMP ADDTO ;跳转到ADDTOH1:SUB AL,30H ;把0到9的字符转换成对应的十六进制数JMP ADDTO ;跳转到ADDTO ADDTO: MOV CL,4 ;相当于让B*乘以16SHL B*

17、,CL ;将B*逻辑左移MOV AH,0 ;将A*清零ADD B*,A* ;A*+B*送到B*JMP NEWCHAR ;跳转到NEWCHAR,把第二个输入的字符存放到B*的第二位E*IT: RETINPUT ENDPOUTPUT PROC NEAR ;显示字符串函数MOV AH,09HINT 21HRETOUTPUT ENDPCHOOSE PROC NEAR ;选择函数MOV AH,1 ;从键盘承受一个数INT 21HCMP AL,1 ;与1比拟JE YES1 ;等于1就跳转到YES1,进展加法CMP AL,2 ;与1比拟JE YES2 ;等于2就跳转到YES2,进展减法CMP AL,3 ;与

18、1比拟 JE YES3 ;等于3就跳转到YES2,进展乘法CMP AL,4 ;与1比拟JE YES4 ;等于4就跳转到YES2,进展除法CMP AL,0 ;与0比拟JE E*IT1 ;等于4就跳转到E*IT1,完毕程序CALL WRONG ;如果不是0到4之间的数就提示出错E*IT1: LEA D*,PR ;D*指向PR换行CALL OUTPUT LEA D*,PR6 ;D*指向PR6,确认是否退出CALL OUTPUT MOV AH,1 ;从键盘承受一个数INT 21HCMP AL,Y ;与Y比拟JE E*IT0 ;不是Y就看是否为yCMP AL,y ;与y比拟JNE START ;不是y就

19、跳转到STARTE*IT0:MOV AH,4CH ;完毕本程序INT 21HYES1:CALL JIA ;调用JIA函数JMP START ;调用完之后跳转到STARTYES2:CALL JIAN ;调用JIAN函数JMP START ;调用完之后跳转到STARTYES3:CALL CHENG ;调用CHENG函数JMP START ;调用完之后跳转到STARTYES4:CALL CHU ;调用CHU函数RET CHOOSE ENDP ;选择函数完毕WRONG PROC NEAR ;报错函数LEA D*,PR ;D*指向PR换行LEA D*,WRO ;D*指向WRO,提示输入有错,请重新输入J

20、MP START ;跳转到STARTRET WRONG ENDP ;报错函数完毕JIA PROC NEAR ;加法函数IN16 ;调用宏,承受键盘输入的两个十六进制数,第一个数由SI指向,第二个数存放在B*中 ADD B*,SI ;把第一个数加第二个数存放到B*中LEA D*,PR ;D*指向PR,换行CALL OUTPUT LEA D*,PR1 ;D*指向PR1,显示A + B=CALL OUTPUT CALL OUTB* ;调用显示B*存放器的容函数RETJIA ENDP ;加法完毕JIAN PROC NEAR ;减法函数IN16 ;调用宏,承受键盘输入的两个十六进制数,第一个数由SI指向

21、,第二个数存放在B*中 SUB B*,SI ;第二个数减第一个数,结果存放到B*中NEG B* ;对结果取反后才是A-B的值,才是第一个数减去第二个数LEA D*,PR ;D*指向PR,换行CALL OUTPUT LEA D*,PR2 ;D*指向PR2,显示A - B=CALL OUTPUT CALL OUTB* ;调用显示B*存放器的容RETJIAN ENDP ;加法函数完毕CHENG PROC NEAR ;乘法函数IN16 ;调用宏,承受键盘输入的两个十六进制数,第一个数由SI指向,第二个数存放在B*中 MOV D*,0 ;把D*清零MOV A*,B* ;把第二个数赋给A* MUL WOR

22、D PTRSI ;A*乘SI并把结果存放到D*,A*中,是字的操作MOV B*,A* ;将A*赋给B*PUSH B* ;将B*压栈,显示下面D*的容时要将D*的值赋给B*PUSH D* ;将D*压栈,因为下面要换行输出,会改变D*的值LEA D*,PR ;D*指向PR,换行输出CALL OUTPUT LEA D*,PR3 ;D*指向PR3,显示A * B=CALL OUTPUT POP D* ;将D*出栈,要将做乘法后D*的容显示出来MOV B*,D* ;把D*给B*CALL OUTB* ;显示D*的容POP B* ;将B*出栈CALL OUTB* ;显示A*的容RETCHENG ENDP ;乘法函数完毕CHU PROC NEAR ;除法函数IN16 ;调用宏,承受键盘输入的两个十六进制数,第一个

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论