微型计算机原理与接口技术第五章.ppt

上传人:小飞机 文档编号:6572693 上传时间:2023-11-13 格式:PPT 页数:80 大小:356.50KB
返回 下载 相关 举报
微型计算机原理与接口技术第五章.ppt_第1页
第1页 / 共80页
微型计算机原理与接口技术第五章.ppt_第2页
第2页 / 共80页
微型计算机原理与接口技术第五章.ppt_第3页
第3页 / 共80页
微型计算机原理与接口技术第五章.ppt_第4页
第4页 / 共80页
微型计算机原理与接口技术第五章.ppt_第5页
第5页 / 共80页
点击查看更多>>
资源描述

《微型计算机原理与接口技术第五章.ppt》由会员分享,可在线阅读,更多相关《微型计算机原理与接口技术第五章.ppt(80页珍藏版)》请在三一办公上搜索。

1、第5章 汇编语言程序设计汇编语言程序的步骤:1)明确任务,确定算法。2)绘流程图。3)根据流程图编写汇编语言程序。4)上机调试程序。,图5-1 标准流程图符号,5.1 汇编语言程序的上机过程1、源文件的建立和汇编(1)建立源程序文件(2)汇编源程序文件汇编程序主要功能:检查源程序中的语法错误并给出出错信息。产生目标文件,列表文件和对照文件。展开宏指令。,汇编操作过程:设在当前C盘上已经建立了一个扩展名为ASM的源程序文件MYASM,汇编时发出如下命令:C:MASM MYASM(或MASM MYASM.ASM)具体的三个输入提示行显示如下:Object Filename MYASM.OBJ:So

2、urce Listing NUL.LST:(可打入源文件名或省略)Cross Reference NUL.CRF:(可打入源文件名或省略)汇编程序对源文件进行汇编,若无错误信息则显示如下结果:0 Warning Errors 0 Severe Errors,2.目标文件的链接连接软件LINK的功能:找到要连接的所有目标文件;确定所有段的地址值;确定所有浮动地址和外部符号所对应的存储地址;生成.EXE可执行文件。,连接软件为 LINK.EXE,其过程如下:设源文件MYASM.ASM已经由汇编软件汇编后生成MYASM.OBJ,其连接命令为:C:LINK MYASM 或 LINK MYASM.OBJ

3、 则在屏幕上显示连接软件的版本号和三个输入提示行,三个输入提示行显示如下:Run File MYASM.EXE:List File NUL.MAP:Libraries.LIB:3.执行文件的调试,5.2 顺序结构程序设计,例5-1 用8086CPU的指令实现Y=(X1+X2)/2的程序设计(1)明确任务,确定算法。(2)绘流程图(图5-3),图5-3 例5-1流程图,(3)根据流程图编写汇编语言程序 1 DATA SEGMENT 2 X1 DB?3 X2 DB?4 Y DW?5 DATA ENDS 6 CODE SEGMENT 7 ASSUME CS:CODE,DS:DATA,8 MAIN P

4、ROC FAR;设置远程调用子程序 9 START:PUSH DS;将DS:0压入堆栈 10 MOVAX,0,11 PUSH AX 12 MOV AX,DATA;为DS设置段值 13 MOV DS,AX 14 MOV AL,X1;取变量X1送AL 15 MOV BL,X2;取变量X2送BL 16 ADD AL,BL 17 ADC AH,0;X1+X2+进位送AX 18 SAR AX,1 19 MOV Y,AX;结果送Y 20 RET 21 MAINENDP 22 CODEENDS 23 ENDSTART,例5-2 将一位十六进制数转换成与它相应的 ASC码。(1)明确任务,确定算法。(2)绘流

5、程图(图5-4),图5-4 例5-2流程,(3)根据流程图编写汇编语言程序DATA SEGMENTTABLE DB 30H,31H,32H,33H,34H,35H,36H,37H DB 38H,39H,41H,42H,43H,44H,45H,46H HEX DB 8 ASC DB?DATA ENDSCOSEG SEGMENT ASSUME CS:COSEG,DS:DATABEING:MOV AX,DATA MOV DS,AX,MOV BX,OFFSET TAB MOV AL,HEX XLAT MOV ASC,AL MOV AH,4CH INT 21HCOSEG ENDS END BEING,5

6、.3 分支结构程序设计,5.3.1 二分支结构 例5-3 要求对不足250个的学生成绩进行统计分析,统计出优秀、及格和不及格的人数。(1)明确任务,确定算法。,(2)绘流程图,图5-6 例5-3流程图,(3)根据流程图编写汇编语言程序 DATA SEGMENT BUF DB N DB N DUP(?)NUM DB 3 DUP(?)DATA ENDS CODE SEGMENT MAIN PROC FAR ASSUME CS:CODE,DS:DATA START:PUSH DS SUB AX,AX PUSH AX MOV AX,DATA MOV DS,AX MOV SI,OFFSET BUF MO

7、V CH,SI;学生个数NCH MOV CL,0;CL存不及格人数,MOV BX,0;BH存优秀人数,BL存及格人数 INC SILP:MOV AH,SI;取学生成绩 CMP AH,90 JB BLOW90;小于90转 INC BH;优秀人数加1 JMP ABOV60 BLOW90:CMP AH,60 JB BLOW60;小于60转ABOV60:INC BL;及格人数加1 JMP NEXTBLOW60:INC CL;不及格人数加1 NEXT:INC SI;数组地址加1 DEC CH;计数减1 JNZ LP MOV SI,OFFSET NUM MOV SI,BH;优秀人数送入内存单元 MOV S

8、I+1,BL;及格人数送入内存单元,MOV SI+2,CL;不及格人数送入内存单元 RETMAIN ENDPCODE ENDS END START5.3.2 多分支结构1.条件逐次测试法例5-4 编程实现使键盘上A、B、C、D六个字母键成为4条输 入命令,使之分别对应不同算法的控制子程序。(1)明确任务,确定算法。(2)绘流程图略,(3)汇编语言程序 MOV AH,l INT 21H;1号功能调用,键盘接收 CMP AL,A;键值为A,转PA子程序 JE PA CMP AL,B;键值为B,转PB子程序 JE PB CMP AL,C;键值为C,转PC子程序 JE PC CMP AL,D;键值为D

9、,转PD子程序 JE PD HLT;键值非A、B、C、D,停止 PA:;A号控制子程序入口 PB:;B号控制子程序入口 PC:;C号控制子程序入口 PD:;D号控制子程序入口,2.列表跳转法例5-5 利用表内地址跳转法来实现例5.4的要求(1)明确任务,确定算法。,(2)绘流程图(图5-8),图5-8 例5-5流程图,(3)根据流程图编写汇编语言程序ADATA SEGMENTBASE DW PA,PB,PC,PDKEY DB?ADATA ENDSASTACK SEGMENT PARA STACK STACK DW 100 DUP(?)TOP LABEL WORDASTACK ENDSACODE

10、 SEGMENT ASSUME CS:ACODE,DS:ADATA,SS:ASTACKSTART:MOV AX,ASTACK MOV SS,AX MOV SP,OFFSET TOP,MOV AX,ADATA MOV DS,AX LOP:MOV AH,1 INT 21H CMP AL,41H JB LOP CMP AL,44H JA LOP SUB AL,41H MOV BX,OFFSET BASE MOV AH,0 ADD AL,AL ADD BX,AX JMP WORD PTRBXACODE ENDS END START,5.4 循环结构程序设计5.4.1 循环程序的组成与结构形式两种循环程

11、序结构:WHILE_DO结构和DO_UNTIL结构,例5-6 试编写一程序统计出某一内存单元中1的个数(1)明确任务,确定算法。(2)绘流程图(图5-11),图5-11 例5-6 流程图,(3)根据流程图编写汇编语言程序DATA SEGMENTXDA DW 3AD8HCONT DB?DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATASTART:MOV AX,DATA MOV DS,AX MOV CL,0 MOV AX,XDA,LOP:CMP AX,0 JZ EXIT SHL AX,1 JNC NEXT INC CLNEXT:JMP LOP EXIT:MOV

12、 CONT,CL INT 20HCODE ENDS END START,5.4.2 循环程序的控制方法(1)计数法计数法分为正计数法和倒计数法。例5-7 编制程序将两个n字节的无符号数相加,结果存入SUM 开始的n+1字节存储区中。(1)明确任务,确定算法。(2)绘流程图略,(3)根据流程图编写汇编语言程序DATA SEGMENTDATA1 DB N DUP(?)DATA2 DB N DUP(?)SUM DB N+1 DUP(?)DATA ENDSCSEG SEGMENT ASSUME CS:CSEG,DS:DATASTART:MOV AX,DATA MOV DS,AX MOV BX,OFFS

13、ET DATA1 MOV SI,OFFSET DATA2 LEA DI,SUM MOV CX,N CLC,LOP:MOV AL,SI ADC AL,BX MOV DI,AL INC BX INC SI INC DI LOOP LOP ADC BYTE PTR DI,0 MOV AH,4CH INT 21H CSEG ENDS END START,(2)条件控制法条件控制法利用已知的条件对循环进行控制的方法。分两种情况:1)如循环最大次数已知,但有可能使用一些特征或条件使循环提前结束。2)循环次数未知,利用条件中的特征结束循环。例5-8 编制程序用单字符输出的DOS功能调用向屏幕输出以“%”结束

14、的字符串。(1)明确任务,确定算法。,(2)绘流程图(图5-12),图5-12 例5-8流程图,(3)根据流程图编写汇编语言程序 DSEG SEGMENT DATA DB HOW ARE YOU?%DSEG ENDS CSEG SEGMENT ASSUME CS:CSEG,DS:DSEG START:MOV AX,DSEG MOV DS,AX LEA SI,DATA,AGAIN:MOV DL,SI CMP DL,%JZ ENDOUT MOV AH,2 INT 21H INC SI JMP AGAINENDOUT:INT 20HCSEG ENDS END START,(3)逻辑尺控制法例5-9

15、设有16个内存单元需要修改,修改规律是:第1、3、6、9、12号单元均加5,其余单元均加10,试用循环结构编程实现。(1)明确任务,确定算法。(2)绘流程图(3)根据流程图编写汇编语言程序,图5-13 例5-9流程图,指针BX0,计数初值CX16,AXXDABX,DX逻辑左移一位,CF=1?,Y,N,AXAX+10,XDABXAX,BXBX+1,CXCX1,CX=0?,N,Y,结束,AXAX+5,DATA SEGMENTXDA DB 16 DUP(?)LRULER DW 0A490HDATA ENDSCODE SEGMENTMAIN PROC FAR ASSUME CS:CODE,DS:DAT

16、ASTART:PUSH DS XOR AX,AX PUSH AX MOV AX,DATA MOV DS,AX MOV BX,0 MOV CX,10H,MOV DX,LRULERAGAIN:MOV AX,XDABX SHL DX,1 JC ADD5 ADD AX,10 JMP SHORT RESULTADD5:ADD AX,5RESULT:MOV XDABX,AX INC BX LOOP AGAIN RETMAIN ENDPCODE ENDS END START,5.4.3 多重循环程序设计注意以下几点:1)设置好各重循环的初始状态,确保各重循环的正常运行。2)注意内外循环嵌套。3)防止死循环现

17、象。例5-10 设某一数组的长度为N,各元素均为字数据,试编制 一个程序使该数组中的数据按照从小到大的次序排 列。(1)明确任务,确定算法。(2)绘流程图(3)根据流程图编写汇编语言程序,图5-14 例5-10流程图,开始,BX0,内循环次数CXN1,外循环次数DXCX,AXDATABX,AXDATABX+2?,交换AX,DATABX+2,DATABXAX,BXBX+2,CXCX1,CX=0?,外循环次数CXDX,BX0,CXCX1,CX=0?,结束,N,Y,Y,N,Y,N,ADATA SEGMENT DATA DW N DUP(?)ADATA ENDSACODE SEGMENT ASSUME

18、 CS:ACODE,DS:ADATASTART:MOV AX,ADATA MOV DS,AX MOV BX,0 MOV CX,N;设计数器CX,内循环次数 DEC CXLOP1:MOV DX,CX;设计数器DX,外循环次数LOP2:MOV AX,DATABX;取相邻两数 CMP AX,DATABX+2;若次序符合,则不交换 JBE CONTI,XCHG AX,DATABX+2;否则两数交换 MOV DATABX,AXCONTI:ADD BX,2 LOOP LOP2;内循环 MOV CX,DX;外循环次数CX MOV BX,0;地址返回第一个数据 LOOP LOP1;外循环 MOV AH,4CH

19、;返回DOS INT 21H ACODE ENDS END START,5.5 子程序结构程序设计子程序是汇编语言中多次使用的一个相对独立的程序段。子程序结构程序设计主要包括三个方面,即:1)子程序的定义与调用 2)子程序的参数传送 3)子程序嵌套与递归调用5.5.1 子程序的定义与调用1、子程序的定义子程序说明包括四个方面:1)描述该子程序模块的名称、功能及性能 2)说明子程序中用到的寄存器和存储单元 3)指出子程序的入口参数和出口参数 4)子程序中调用其它子程序的名称,例5-11 定义一个显示两位十六进制数的子程序程序说明:;名称:DISPP;功能:显示两位十六进制数;所用寄存器CX,DX

20、;人口参数:AL存放两位十六进制数;出口参数:无;调其它子程序:DISP1,子程序;DISPP PROC NEAR PUSH DX PUSH CX MOV DL,AL MOV CL,4 ROL DL,CL AND DL,0FH CALL DISP1 MOV DL,AL AND DL,0FH CALL DISP1 POP CX POP DX RET DISPP ENDP,2、子程序的调用和返回例5-12 编制显示四位十六进制数的子程序(1)明确任务,确定算法。(2)绘流程图(3)根据流程图编写汇编语言程序,DISP4 PROC NEAR PUSH BX PUSH CX PUSH DX PUSH

21、AX MOV AL,AH CALL DISP2 POP AX CALL DISP2 POP DX POP CX POP BX RET DISP4 ENDP DISP2 PROC NEAR MOV BL,AL MOV DL,AL MOV CL,4,ROL DL,CL AND DL,0FH CALL DISP1 MOV DL,BL AND DL,0FH CALL DISP1 RETDISP2 ENDPDISP1 PROC OR DL,30H CMP DL,3AH JB DDD ADD DL,07H DDD:MOV AH,2 INT 21H RETDISP1 ENDP,5.5.2 子程序的参数传送

22、实现参数传送分为四种:寄存器传送、固定缓冲区传送、地址表传送和堆栈传送。1、寄存器传送 寄存器传送是一种最常用、最简单的参数传送实现方法。2、固定缓冲区传送 固定缓冲区传送方法是采用存储器来实现参数传送的,它与寄存器传送类似。例5-13 已知数组由100个字数据组成,试编程求出这个数组 元素之和。,(1)明确任务,确定算法。(2)绘流程图(图5-16),图5-16 例5-13求和子程序流程图,(3)根据流程图编写汇编语言程序DATA SEGMENT ARY DW 100 DUP(?)SUM DW?DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA STA

23、RT:MOV AX,DATA MOV DS,AX CALL RADD MOV AH,4CH INT 21H;求和子程序 RADD PROC NEAR PUSH AX PUSH BX PUSH CX PUSH DX LEA BX,ARY,MOV CX,100 XOR AX,AX MOV DX,AX CL1:ADD AX,BX JNC CL2 INC DX CL2:ADD BX,2 LOOP CL1 MOV SUM,AX MOV SUM+2,DX POP DX POP CX POP BX POP AX RET RADD ENDP CODE ENDS END START,3、地址表传送地址表传送是采

24、用存储器来实现参数传送的。例5-14 已知数组A由100个字数据组成,数组B由50个字数据组成,试编程分别求出这两个数组元素之和。(1)明确任务,确定算法。(2)绘流程图(图5-17)(3)根据流程图编写汇编语言程序,图5-17 例5-14流程图,DATA SEGMENT CA DW 100 ARA DW 100 DUP(?)SA DD?CB DW 50 ARB DW 50 DUP(?)SB DD?TAB DW 3 DUP(?)DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA START:MOV AX,DATA MOV DS,AX MOV AX,OFF

25、SET CA MOV TAB,AX MOV AX,OFFSET ARA MOV TAB2,AX,MOV AX,OFFSET SA MOV TAB 4,AX MOV SI,OFFSET TAB CALL RADD MOV AX,OFFSET CB MOV TAB,AX MOV AX,OFFSET ARB MOV TAB2,AX MOV AX,OFFSET SB MOV TAB 4,AX MOV SI,OFFSET TAB CALL RADD MOV AH,4CH INT 21H RADD PROC NEAR MOV BX,SI,MOV CX,BX MOV BX,SI+2 MOV DI,SI+4

26、XOR AX,AX MOV DX,AX CL1:ADD AX,BX JNC CL2 INC DX CL2:ADD BX,2 LOOP CL1 MOV DI,AX MOV DI+2,DX RET RADD ENDP CODE ENDS END START,4、堆栈传送堆栈传送是采用存储器来实现参数传送的。例5-15 已知数组A由100个字数据组成,数组B由50个字数据组成,要求用堆栈传送参数的子程序结构编程,试分别求出这两个数组元素之和。1)明确任务,确定算法。2)绘流程图(图5-18)3)根据流程图编写汇编语言程序,结束,数组A起始地址压入堆栈,开始,存放数组A长度起始地址压入堆栈,存放数组A

27、和起始地址压入堆栈,数组B起始地址压入堆栈,存放数组B长度起始地址压入堆栈,存放数组B和起始地址压入堆栈,调用求和子程序RADD,调用求和子程序RADD,图5-18 例5-15流程图,DATA SEGMENTCNTA DW 100ARYA DW 100 DUP(?)SUMA DD?CNTB DW 50ARYB DW 50 DUP(?)SUMB DD?DATA ENDSCSEG SEGMENT ASSUME CS:CSEG,DS:DATASTART:MOV AX,DATA MOV DS,AX MOV AX,OFFSET ARYA PUSH AX MOV AX,OFFSET CNTA,PUSH A

28、X MOV AX,OFFSET SUMA PUSH AX CALL NEAR PTR RADD MOV AX,OFFSET ARYB PUSH AX MOV AX,OFFSET CNTB PUSH AX MOV AX,OFFSET SUMB PUSH AX CALL NEAR PTR RADD MOV AH,4CH INT 21HRADD PROC NEAR PUSH BP,MOV BP,SP PUSH AX PUSH DX PUSH CX PUSH SI PUSH DI MOV SI,BP8 MOV DI,BP6 MOV CX,DI MOV DI,BP4 XOR AX,AX MOV DX,A

29、X NEXT:ADD AX,SI JNC NOCAY INC DX,NOCAY:ADD SI,2 LOOP NEXT MOV DI,AX MOV DI2,DX POP DI POP SI POP CX POP DX POP AX POP BP RET 6 RADD ENDP CSEG ENDS END START,5.5.3 子程序嵌套与递归调用1、子程序嵌套子程序嵌套是指一个子程序的内部再调用其他子程序。,图5-20 子程序嵌套,2、递归子程序递归子程序是这种具有递归调用性质的子程序。递归子程序必须注意以下两点:1)注意现场的保护。2)注意递归结束条件。例5-16 计算 S=X!+Y!其中X

30、、Y的值在08之间。(1)明确任务,确定算法。,(2)绘流程图,图5-21 例-16流程图,(3)根据流程图编写汇编语言程序DATA SEGMENT XYVAL DW?,?SVAL DW 0 DATA ENDS STACK1 SEGMENT PARA STACK STACK TOP DW 64H DUP(0)STACK1 ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK1 START:MOV AX,DATA MOV DS,AX MOV AX,STACK1 MOV SS,AX MOV SP,SIZE TOP,MOV SI,OFFSET XYVAL

31、 MOV BX,SI CALL FT PUSH AX MOV BX,SI+2 CALL FT POP BX ADD AX,BX MOV SVAL,AX MOV AH,4CH INT 21H;求阶乘子程序 FT PROC NEAR AND BX,BX,JZ FT1 PUSH BX DEC BX CALL FT POP BX MUL BX RET FT1:MOV AX,1 RET FT ENDP CODE ENDS END START,图5-22 递归调用过程的堆栈变化情况,5.6 模块化程序设计1、模块化程序设计的优点模块化程序设计是将复杂的程序划分成多个程序模块。优点:1)对大型程序设计来说,

32、便于程序员之间分工,可由多人编写和调试,这样加快了程序的开发速度;2)对单个程序模块而言,易于编写、调试和修改;3)整个程序易读、易理解,程序的修改可局部进行,不会影响其它部分;4)对频繁使用的功能程序段可以编制成模块,供多个任务使用,这样不仅使程序更简洁而且能提高编程效率。,2、模块化程序设计步骤步骤:1)明确任务,正确地描述整个程序需要完成的各项功能;2)根据各项功能与整个程序的关系,把整个程序划分成多个功能模块,并画出模块层次图;3)确切地定义每个功能模块做些什么,以及与其他功能模块之间的联系,并写出各模块的说明;4)把每个功能模块编制成程序,并进行独立汇编、调试,得到与各功能模块相应的

33、目标模块;5)由连接程序将各目标模块连接在一起,构成一个完整的可执行程序;6)最后,把整个程序及所有的模块说明合在一起,形成一个模块化程序设计文件。,3、模块化程序设计方法(1)模块划分的方法模块的划分一般应遵循以下原则:1)高内聚2)低耦合3)长度适中,(2)模块划分的描述,图5-23 模块划分的描述,(3)模块化程序设计技术1)模块化程序实现方法:子程序结构和宏结构子程序结构:在汇编语言程序设计中,采用子程序结 构设计是实现模块化程序设计的重要手 段。宏结构:在汇编语言程序设计中,提供了宏定义功能,采用宏定义、调用和展开来进行程序设计也 是实现程序模块化的重要技巧。2)多模块的连接,例5-17 设有三个模块M1、M2、M3,模块M1含有三个段,段名分别为A、B、C,与之对应的组合类型分别为PUBLIC、COMMON和STACK;模块M2含有两个段,段名分别为A、C,与之对应的组合类型分别为PUBLIC和STACK;模块M3含有三个段,段名分别为A、B、C,与A、B段对应的组合类型分别为PUBLIC、COMMON;C段没有指定组合类型。试说明经连接程序LINK对段进行组合处理后产生哪些段?,3)模块间标识符的交叉访问 4)模块间数据传送的其它方法,

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号