1、作者:陈国富 汇编语言设计课程设计汇编语言课程设计报告( 2013 - 2014 年度第1 学期)实现加减乘除四则运算的计算器专业计算机科学与技术学生姓名班级学号指导教师完成日期1 目录1 概 述11.1 设计目的11.2 设计内容12实现方法12.1 实现的目标12.2 主体的功能12.3 开发的环境13 设计方法概要23.1功能模块划分23.2流程图34详细设计35 程序调试45.1 调试方案45.2 调试结果46结论5参考文献6附 录7附录 源程序清单73实现加减乘除四则运算的计算器1 概 述 1.1 设计目的本课程设计是在学完教学大纲规定的全部内容、完成所有实践环节的基础上,旨在深化学
2、生学习的汇编语言课程基本知识,进一步掌握汇编语言程序设计方法,提高分析问题、解决问题的综合应用能力。1.2 设计内容能实现加、减、乘、除的计算;该程序接受的是16进制数;执行时,需要在文件名后直接跟上计算表达式,如在命令提示符下执行结果如下:c:tasmjs 3+25 2实现方法2.1 实现的目标本次汇编语言课程设计的最终目的是要实现一个简单加减乘除四则运算的计算器,要求编写一个程序,每运行一次可执行程序,可以实现数的加减乘除四则运算。比如,十进制数的加减乘除四则运算。我们曾经学习过两个具体数字进行加减法运算,但是对于简单计算器用汇编语言实现难点在于这两个要做运算的数是未知的,是由自己调用中断
3、输入到屏幕上并要用程序存储起来的数,然后才能对这两个数进行运算,而且做的是加法运算、减法运算乘法运算还是除法运算也未可知,为此我们还要判断用户所输入的运算是四则运算中的哪一个运算。此外,运算过程中的进位或是借位,选择用什么样的方式进行输出,如何实现清屏等也是要解决的问题。2.2 主体的功能系统分析主要包括设计的功能分析和系统的流程,功能分析放在首位,每一个软件都要能满足一定的功能才有使用价值。根据功能需求来创建应用程序。本设计的功能如下: 1、输入2个数,先判断是加减运算还是乘除运算,再进行计算 2、判断符号是否为运算符 3、回车为换行符 4、用十进制或十六进制输出运算结果2.3 开发的环境T
4、ASM5.0集成环境3 设计方法概要3.1功能模块划分本题目实现的模块图如图3-1所示四则运算计算器程序设计界面设置选择算法设置十进制转换设置图3-1 概要模块(1) 界面设置 主要实现确定界面样式的功能,以菜单形式显示。(2) 选择算法设置 用于选择加、减、乘、除法来进行运算。(3) 十进制转换设置 应用十进制的转换算法来处理加、减、乘、除法四则运算。3.2流程图输入选择键xX=1?X=2?X=3?X=4?十六进制加法十六进制减法十六进制乘法十六进制除法提示出错!X=0??是是是否是否否否否X=Y/y ??否是是开 始结 束图3.2.1四则运算计算器执行过程流程图4详细设计4.1 界面设置
5、通过定义数据段,利用09H显示出功能列表。通过定义数据段,以字符串的形式输入每个提示信息,利用09H键盘输入并回显命令显示每一个功能提示,是计算器的功能列表有序清晰的显示在屏幕上。4.2 选择算法设置首先选择要进行的四则运算,若选择1,则进行加法;若选择2,则进行减法;若选择3,则进行乘法;若选择4,则进行除法。加法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入BX中,然后显示BX 和SI中的内容相加存在BX中。减法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入BX中,然后显示BX 和SI中的内容相减存在BX中,然后用NEG来求反
6、,即为第一个数减去第二个数的差,显示BX的内容即为差。乘法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入BX中,把BX的值给AX,然后让AX乘以SI,然后再分别将DX,AX中的内容赋给BX,接着依次显示DX,AX的内容,即为积。除法:先输入第一个小于4位十六进制数存入SI中,在输入第二个小于4位十六进制数存入BX中,将SI赋给AX作被除数,让BX作除数,得到的商存放在AX中,余数放在DX中,然后依次赋给BX,将其依次显示即为商。4.3 十进制转换设置 要完成十进制转换成十六,一般采用除十六取余法来完成,其大致过程如下:将待转换的数除以16得到第一个商和余数,此第
7、一个余数就是所求的十六进制数的各位,再用第一个商除以16,得到第二个商和余数,此第二个余数就是所求十六进制数的十位,重复这一过程直至商为0,此时的余数就是所求十六进制数的最高位。在内存中分配一缓冲区,用来存放以上分离出来的使十进制数的每一位,然后再逐个转换成ASCII码,转换成ASCII码的过程很简单,就是给每个十六进制位加上30H即可,最后送显示器输出。5 程序调试5.1 调试方案对程序源代码进行功能调试和功能验证。程序代码运行成功后,分别检验测试其加、减、乘、除功能,并对结果进行分析。当用户选择0时,输入Y或N决定是否退出程序。5.2 调试结果输入数字进行加减乘除运算,计算结果如下图所示:
8、测试结束后,退出程序,如下图所示:6结论程序的主要功能是实现四则运算,整个程序中主要分为,输入算式,加法,减法,乘法,除法和以十进制显示结果这几个部分。通过这次课程设计,我发现一个好的汇编程序不仅要正确可行,还要有健壮性,当用户输入数据非法,使运行环境改变时,程序能恰当地作出反应或进行处理,不会产生莫名其妙的输出结果。一个正确可行的算法如果缺乏健壮性,那么这个程序也不能算真正的成功。经过为期一周的汇编语言课程设计,亲身感受体验敲、改写程序代码的乐趣,我对汇编语言有了较为深入的了解,不仅巩固了以前在课本上学到的知识,还学会了很多其他东西。通过这次课程设计,我收获的不仅仅是课程上的知识得到实际应用
9、,还有编程的基本习惯和开发系统时应注意的流程。作为一个程序编程人员,要保持清醒的头脑,以现实为依据,让自己的每一行代码都能实现自己的意义。由于能力有限,程序还是有不完美的地方。这次的综合实验让我对汇编有了更深刻的认识,对各种指令有了进一步的理解。11 参考文献1 刘其明.汇编语言程序设计教程.徐州:中国矿业大学出版社,20102 钱晓捷.新版汇编语言程序设计.北京:电子工业出版社,20073 何小海,严华. 微机原理与接口技术.北京:科学出版社,20064沈美明,温冬婵. IBM-PC汇编语言程序设计 M. 清华大学出版社5王爽 汇编语言 M.清华大学出版社附 录附录 源程序清单IN16 MA
10、CRO ;完成从键盘接受二个数并转换为十六制数,第一个数由SI指向,第二个数存放在BX中 LEA DX,PR ;DX指向PR换行CALL OUTPUT ;LEA DX,INPUT1 ;DX指向INPUT1,提示输入第一个数CALL OUTPUT CALL INPUT ;把输入的数存放在BX中LEA SI,RESULT ;SI指向RESULTMOV SI,BX ;把第一个十六制数存入RESULT的第一个位置LEA DX,PR ;DX指向PR,换行CALL OUTPUT LEA DX,INPUT2 ;DX指向INPUT2,提示输入第一个数CALL OUTPUT CALL INPUT ;把输入的数存
11、放在BX中ENDM ;宏结束DATA SEGMENT ;数据段BUF DB ,0DH,0AHDB *- WELCOME 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 number:,$ INPUT1 DB Please input the first number xiao yu 4 wei:,$INPUT2 DB Please input the second numb
12、er xiao 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=$PR5 DB .$PR6 DB Are you sure exit?(Y/N)$ DATA ENDS ;数据段落定义结束CODE SEGMENTMAIN PROC FAR ;主函数ASSUME CS:
13、CODE ,DS:DATASTART:MOV AX,DATAMOV DS,AXLEA DX,BUF ;DX指向BUF换行CALL OUTPUT ;调用显示字符串函数换行SUB AX,AX ;AX清零CALL CHOOSE ;调用选择函数JMP START ;跳转到STARTRET MAIN ENDPINPUT PROC NEAR ;定义INPUT函数,就是将从键盘输入的数按原十六进制数存放在BX中MOV BX,0 ;BX清零NEWCHAR:MOV AH,1 INT 21H ;接受键盘输入一个字符CMP AL,0DH ;输入的字符与回车比较JE EXIT ;是回车就结束 CMP AL,A ;与A
14、比较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 ;相当于让BX乘以16SHL BX,CL ;将BX逻辑左移MOV AH,0 ;将AX清零ADD BX,AX ;AX+BX送到BXJMP NEWCHAR ;跳转到NEWCHAR,把第二个输入的字符存放到BX的第二位EXIT: RET
15、INPUT 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 ;与1比较 JE YES3 ;等于3就跳转到YES2,进行乘法CMP AL,4 ;与1比较JE YES4 ;等于4就跳转到YES2,进行除法CMP AL,0 ;与0比较JE EXIT1 ;等于4就跳转
16、到EXIT1,结束程序CALL WRONG ;如果不是0到4之间的数就提示出错EXIT1: LEA DX,PR ;DX指向PR换行CALL OUTPUT LEA DX,PR6 ;DX指向PR6,确认是否退出CALL OUTPUT MOV AH,1 ;从键盘接受一个数INT 21HCMP AL,Y ;与Y比较JE EXIT0 ;不是Y就看是否为yCMP AL,y ;与y比较JNE START ;不是y就跳转到STARTEXIT0:MOV AH,4CH ;结束本程序INT 21HYES1:CALL JIA ;调用JIA函数JMP START ;调用完之后跳转到STARTYES2:CALL JIAN
17、 ;调用JIAN函数JMP START ;调用完之后跳转到STARTYES3:CALL CHENG ;调用CHENG函数JMP START ;调用完之后跳转到STARTYES4:CALL CHU ;调用CHU函数RET CHOOSE ENDP ;选择函数结束WRONG PROC NEAR ;报错函数LEA DX,PR ;DX指向PR换行LEA DX,WRO ;DX指向WRO,提示输入有错,请重新输入JMP START ;跳转到STARTRET WRONG ENDP ;报错函数结束JIA PROC NEAR ;加法函数IN16 ;调用宏,接受键盘输入的两个十六进制数,第一个数由SI指向,第二个数
18、存放在BX中 ADD BX,SI ;把第一个数加第二个数存放到BX中LEA DX,PR ;DX指向PR,换行CALL OUTPUT LEA DX,PR1 ;DX指向PR1,显示A + B=CALL OUTPUT CALL OUTBX ;调用显示BX寄存器的内容函数RETJIA ENDP ;加法结束JIAN PROC NEAR ;减法函数IN16 ;调用宏,接受键盘输入的两个十六进制数,第一个数由SI指向,第二个数存放在BX中 SUB BX,SI ;第二个数减第一个数,结果存放到BX中NEG BX ;对结果取反后才是A-B的值,才是第一个数减去第二个数LEA DX,PR ;DX指向PR,换行CA
19、LL OUTPUT LEA DX,PR2 ;DX指向PR2,显示A - B=CALL OUTPUT CALL OUTBX ;调用显示BX寄存器的内容RETJIAN ENDP ;加法函数结束CHENG PROC NEAR ;乘法函数IN16 ;调用宏,接受键盘输入的两个十六进制数,第一个数由SI指向,第二个数存放在BX中 MOV DX,0 ;把DX清零MOV AX,BX ;把第二个数赋给AX MUL WORD PTRSI ;AX乘SI并把结果存放到DX,AX中,是字的操作MOV BX,AX ;将AX赋给BXPUSH BX ;将BX压栈,显示下面DX的内容时要将DX的值赋给BXPUSH DX ;将
20、DX压栈,因为下面要换行输出,会改变DX的值LEA DX,PR ;DX指向PR,换行输出CALL OUTPUT LEA DX,PR3 ;DX指向PR3,显示A * B=CALL OUTPUT POP DX ;将DX出栈,要将做乘法后DX的内容显示出来MOV BX,DX ;把DX给BXCALL OUTBX ;显示DX的内容POP BX ;将BX出栈CALL OUTBX ;显示AX的内容RETCHENG ENDP ;乘法函数结束CHU PROC NEAR ;除法函数IN16 ;调用宏,接受键盘输入的两个十六进制数,第一个数SI指向,第二个数存放在BX中MOV AX,SI ;将第一个数赋给AXMOV
21、 DX,0 ;将DX清零DIV BX ;AX除BX,结果存放到DX,AX,DX存放余数,AX存放商PUSH DX ;压栈DXPUSH AX ;压栈AXLEA DX,PR ;DX指向PR,换行CALL OUTPUT LEA DX,PR4 ;DX指向PR4,显示A / B=CALL OUTPUT POP AX ;出栈AXMOV BX,AX ;将AX赋给BX,将商给BXCALL OUTBX ;显示AX寄存器的内容,即显示商LEA DX,PR5 ;DX指向PR5,显示省略号CALL OUTPUT POP DX ;出栈DXMOV BX,DX ;将DX赋给BX,即将余数赋给BX,CALL OUTBX ;显
22、示DX寄存器的内容,显示余数RET CHU ENDP ;除法函数结束OUTBX PROC NEAR ;显示BX寄存器的内容函数MOV CH,4 ;CH等于4ROTATE:MOV CL,4 ;CL等于4ROL BX,CL ;将BX循环左移4位MOV AL,BL ;将BL赋给ALAND AL,0FH ;将AL的高位置0ADD AL,30H ;AL+30H可将AL变为对应的ASCII的值CMP AL,3AH ;判断是否是0-9之间JL PRINTIT ;是则跳转到PRINTITADD AL,7H ;是A-F再加上7HPRINTIT:MOV DL,AL ;将AL赋给DLMOV AH,2 INT 21H ;显示ALDEC CH ;CH-1再赋给CHJNZ ROTATE ;CH!=0则跳转到ROTATERET ;CH=0则结束OUTBX ENDP ;显示寄存器BX内容函数结束CODE ENDSEND MAIN