计算机硬件课程设计实验报告.doc

计算机硬件课程设计实验报告.doc

ID:49686706

大小:475.50 KB

页数:8页

时间:2020-03-02

计算机硬件课程设计实验报告.doc_第1页
计算机硬件课程设计实验报告.doc_第2页
计算机硬件课程设计实验报告.doc_第3页
计算机硬件课程设计实验报告.doc_第4页
计算机硬件课程设计实验报告.doc_第5页
资源描述:

《计算机硬件课程设计实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、上海电力学院课程设计(大型作业)实验报告(2010/2011学年第1学期)课题名称计算机硬件技术实践课题代码软件类题目(12)院(系)电自学院(信控系)专业班级学生学号时间2011.01.09~2011.01.13设计目的通过本项课程设计,对微机原理课程中涉及的芯片结构、控制原理、硬件编程等方面有一定的感性认识和实践操作能力,更好的理解微机原理课程中讲述的基本原理和概念。二、设计题目软件类设计题目(12)排序程序(从首地址为1000H开始存放50个数,要求设计程序将这些数由小到大排序,排序后的数,仍数在该区域中。)三、开发目的通过汇编语

2、言实现排序,按要求从首地址为1000H开始存放50个数,然后通过冒泡法进行排序,并将排序后的数保留在该区域内。通过本次设计达到加深对汇编语言的了解和掌握的目的。四、小组成员及分工我所编写的程序如下:DSEGSEGMENTMEMDB50DUP(?)DSEGENDSCSEGSEGMENTASSUMECS:CSEG,DS:DSEGSTART:MOVAX,DSEGMOVDS,AXLEADI,MEMMOVBL,49NEXT1:MOVSI,1000HMOVCL,BLNEXT2:MOVAL,ES:[SI]INCSICMPAL,ES:[SI]JCNEX

3、T3MOVDL,ES:[SI]MOVES:[SI-1],DLMOVES:[SI],ALNEXT3:DECCLJNZNEXT2DECBLJNZNEXT1MOVAH,4CHINT21HCSEGENDSENDSTART本程序通过比较指令CMP和条件转移指令JNC来实现无符号数的比较。先是第一个数与下一个数比较,若小于则是其位置保持不变,小于则将大数方高地址,小数放低地址。再通过第二重49次循环,既可实现对50个无符号数的大小排序。五、程序流程图六、源程序清单DSEGSEGMENTELEMDB3,?,3DUP(?)WDW0MEMDB10DUP(

4、?)DSEGENDSCSEGSEGMENTASSUMECS:CSEG,DS:DSEGSTART:MOVAX,DSEGMOVDS,AXMOVBL,10MOVSI,0NEXT0:LEADX,ELEMMOVAH,0AHINT21HMOVCL,[ELEM+1]LEADI,ELEM+2PUSHBXPUSHSICALLCALCULATIONPOPSIPOPBXMOVAL,BYTEPTR[W]MOVMEM[SI],ALINCSIDECBLJNZNEXT0LEASI,MEMMOVDI,1000HMOVCL,10CLDREPMOVSBMOVBL,9NEX

5、T1:MOVSI,1000HMOVCL,BLNEXT2:MOVAL,ES:[SI]INCSICMPAL,ES:[SI]JCNEXT3MOVDL,ES:[SI]MOVES:[SI-1],DLMOVES:[SI],ALNEXT3:DECCLJNZNEXT2DECBLJNZNEXT1MOVAH,4CHINT21HCALCULATIONPROCNEARPUSHCXDECCXLEASI,ELEM+1TT1:INCSIORCX,0HJNZTT2POPCXJMPL0TT2:DECCXJMPTT1L0:MOVAX,0MOVW,AXMOVAX,1L1:P

6、USHAXMOVDH,30HMOVBX,10MOVDL,[SI]SUBDL,DHXORDH,DHMULDXADDW,AXPOPAXMULBXDECSILOOPL1RETCALCULATIONENDPCSEGENDSENDSTART七、程序运行结果及预测八、结果评述与总结这次实践课程的结果还是令人比较满意的,我们在这次实践课程中重新温习了比较指令与相关DOS指令的定义与运用,通过小组讨论与老师的指导,成功的运用了汇编程序进行编程。首先我们先完成了最基础的字符串匹配程序,当中我们还考虑到了不仅要判断字符串的内容是否一致,还要考虑到两个字符串

7、的长短是否是一样的。根据这个思路我们设计出了第一个版本的程序,但是之后在改进程序的过程中我们又想到了除了可以进行字符串的比较是否匹配,是不是也可以设计程序告诉用户,假使两个字符串不匹配,到底从哪个字符开始不匹配的。思路出来之后,问题也出现了,如何去实现这个功能?我们想过许多办法,比如创建堆栈之类的来实现,也去网上查过资料、同别的组讨论过。最后决定使用定义一个变量然后调用DOS功能调用来实现,具体方法是首先定义一个变量D8赋值为0,然后在COMPARE1中,每一次比较前都执行一次“INCD8”指令,一旦程序发现两个字符不匹配时,跳转到NO

8、MATCH1后,程序就会把D8中的内容移到AH中并执行DOS9号功能输出出来给用户。经过了几次试验之后终于成功的输出了我们想要得到的结果。最后的我们汇编出的程序就有了以下的功能:在长度不一的不匹配情况,以及

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。