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

更新时间:2024-04-12 09:26:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

上 海 电 力 学 院

课程设计(大型作业)实验报告

(2010 /2011学年第1学期)

课题名称 课题代码院(系) 专 业 班 级 学 生 学 号 时 间

计算机硬件技术实践

软件类题目(12)

电自学院(信控系) 2011.01.09~2011.01.13

一、 设计目的

通过本项课程设计,对微机原理课程中涉及的芯片结构、控制原理、硬件编程等方面有一定的感性认识和实践操作能力,更好的理解微机原理课程中讲述的基本原理和概念。

二、 设计题目

软件类设计题目

(12)排序程序(从首地址为1000H开始存放50个数,要求设计程序将这些数由小到大排序,排序后的数,仍数在该区域中。)

三、开发目的

通过汇编语言实现排序,按要求从首地址为1000H开始存放50个数,然后通过冒泡法进行排序,并将排序后的数保留在该区域内。通过本次设计达到加深对汇编语言的了解和掌握的目的。

四、小组成员及分工

我所编写的程序如下: DSEG SEGMENT MEM DB 50 DUP(?) DSEG ENDS

CSEG SEGMENT

ASSUME CS:CSEG,DS:DSEG START: MOV AX,DSEG MOV DS,AX LEA DI,MEM MOV BL,49

NEXT1: MOV SI,1000H MOV CL,BL

NEXT2: MOV AL,ES:[SI] INC SI

CMP AL,ES:[SI] JC NEXT3

MOV DL,ES:[SI] MOV ES:[SI-1],DL MOV ES:[SI],AL

NEXT3: DEC CL JNZ NEXT2

DEC BL JNZ NEXT1

MOV AH,4CH INT 21H CSEG ENDS END START

本程序通过比较指令CMP和条件转移指令JNC来实现无符号数的比较。先是第一个数与下一个数比较,若小于则是其位置保持不变,小于则将大数方高地址,小数放低地址。再通过第二重49次循环,既可实现对50个无符号数的大小排序。

五、程序流程图

六、源程序清单 DSEG SEGMENT

ELEM DB 3,?,3 DUP(?) W DW 0

MEM DB 10 DUP(?) DSEG ENDS

CSEG SEGMENT

ASSUME CS:CSEG,DS:DSEG START: MOV AX,DSEG MOV DS,AX MOV BL,10 MOV SI,0

NEXT0: LEA DX,ELEM MOV AH,0AH

INT 21H

MOV CL,[ELEM+1] LEA DI,ELEM+2 PUSH BX PUSH SI

CALL CALCULATION POP SI POP BX

MOV AL,BYTE PTR[W] MOV MEM[SI],AL INC SI DEC BL JNZ NEXT0

LEA SI,MEM MOV DI,1000H MOV CL,10 CLD

REP MOVSB

MOV BL,9

NEXT1: MOV SI,1000H MOV CL,BL

NEXT2: MOV AL,ES:[SI] INC SI

CMP AL,ES:[SI] JC NEXT3

MOV DL,ES:[SI] MOV ES:[SI-1],DL MOV ES:[SI],AL

NEXT3: DEC CL JNZ NEXT2

DEC BL JNZ NEXT1

MOV AH,4CH INT 21H

CALCULATION PROC NEAR

PUSH CX

DEC CX

LEA SI,ELEM+1 TT1: INC SI OR CX,0H JNZ TT2 POP CX JMP L0

TT2: DEC CX

JMP TT1

L0: MOV AX,0 MOV W,AX MOV AX,1 L1: PUSH AX MOV DH,30H MOV BX,10 MOV DL,[SI] SUB DL,DH XOR DH,DH MUL DX ADD W,AX POP AX MUL BX DEC SI LOOP L1 RET

CALCULATION ENDP

CSEG ENDS END START

七、程序运行结果及预测

八、结果评述与总结

这次实践课程的结果还是令人比较满意的,我们在这次实践课程中重新温习了比较指令与相关DOS指令的定义与运用,通过小组讨论与老师的指导,成功的运用了汇编程序进行编程。首先我们先完成了最基础的字符串匹配程序,当中我们还考虑到了不仅要判断字符串的内容是否一致,还要考虑到两个字符串的长短是否是一样的。根据这个思路我们设计出了第一个版本的程序,但是之后在改进程序的过程中我们又想到了除了可以进行字符串的比较是否匹配,是不是也可以设计程序告诉用户,假使两个字符串不匹配,到底从哪个字符开始不匹配的。思路出来之后,问题也出现了,如何去实现这个功能?我们想过许多办法,比如创建堆栈之类的来实现,也去网上查过资料、同别的组讨论过。最后决定使用定义一个变量然后调用DOS功能调用来实现,具体方法是首先定义一个变量D8赋值为0,然后在COMPARE1中,每一次比较前都执行一次“INC D8”指令,一旦程序发现两个字符不匹配时,跳转到NOMATCH1后,程序就会把D8中的内容移到AH中并执行DOS 9号功能输出出来给用户。经过了几次试验之后终于成功的输出了我们想要得到的结果。最后的我们汇编出的程序就有了以下的功能:在长度不一的不匹配情况,以及长度相同时的匹配和不匹配情况下分别进行判断,并且在不匹配的时候告知用户是从第几位开始出现不匹配情况。对于这个实践结果我们还是感到很满意的。

本文来源:https://www.bwwdw.com/article/ozzp.html

Top