汇编语言 子程序结构
第六章 子程序结构
![第六章 子程序结构](https://img.taocdn.com/s3/m/fa8b6a13581b6bd97f19ea79.png)
( (SP)+1,(SP) ) ← (CS) (SP) ← (SP) - 2 ( (SP)+1,(SP) ) ← (IP) (IP) ← (EA) (CS) ← (EA+2)
2.子程序返回指令RET 返回指令为子程序最后执行的指令,作用为断点出
LENTH DW
?
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: MOV AX,DATA
MOV DS,AX
LEA SI,STRG
;SI为字符串首地址,作入口参数
CALL SCONT
;调用子程序
MOV LENTH,BX
;保存结果
MOV AH,4CH
INT 21H
第六章 子程序结构
§6.1 子程序的设计方法 §6.2 嵌套与递归子程序 §6.3 子程序举例 §6.4 DOS系统功能调用
§6.1 子程序的设计方法
➢把功能相对独立的程序段单独编写和调试, 作为一个相对独立的模块供程序使用,就形 成子程序 ➢子程序可以实现源程序的模块化,可简化 源程序结构,可以提高编程效率
SCONT NEXT:
OVER: SCONT CODE
PROC XOR CMP JZ INC INC JMP
RET ENDP ENDS END
NEAR BX,BX BYTE PTR [SI],-1 OVER BX SI NEXT
START
;BX寄存器用于统计结果 ;是否结束标志 ;是则转OVER ;统计 ;修改地址指针
分析:本题子程序的功能是统计字符串长度,只需要将被 统计字符串的首地址作为入口参数传递给子程序即可。统计的 结果放在某个寄存器如BX返回即可。程序如下:
子程序的结构
![子程序的结构](https://img.taocdn.com/s3/m/5e9770d1a5e9856a5712609b.png)
汇编语言程序设计
汇编语言程序设计
子程序的结构
子程序又称为过程或者函数,是一段能够独立的完成 某项功能的程序段。每一个子程序都是由子程序的定义 和子程序的调用构成。
1.子程序
子程序的结构包括: 子程序的定义;子程序的程序段;子程序的返回。 设计子程序,与程序的设计方法完全相同,可以采用顺 序、分支和循环结构;不同之处只是在于子程序的程序 段只有被调用时,其代码才能称为过程调用,本书称为主程序调用。 当主程序在需要调用子程序时,可以使用调用指令直接 调用已经定义的子程序,转去执行子程序的程序段,执 行完成后,由返回指令直接返回到主程序中调用指令的 下一条指令继续执行主程序。
3.子程序与循环结构的区别 两者都是重复执行一些相同的程序段,但循环结构每次 处理的数据都必须具有一定的规律,而子程序的程序段 每次处理的数据可以是任意的。可见,当需要对不同的 数据进行相同的处理时,应当采用子程序结构。
汇编语言程序设计的基本方法
![汇编语言程序设计的基本方法](https://img.taocdn.com/s3/m/49c840a66037ee06eff9aef8941ea76e59fa4a76.png)
01
例2 编写程序,计算(W-(X*Y+Z-100))/W,其中W、X、Y、Z均为16位带符号数,计算结果的商存入AX,余数存入DX。
02
例3 把非压缩十进制数DAT1转换为压缩十进制数
例2编写程序,计算(W-(X*Y+Z-100))/W,其中W、X、Y、Z均为16位带符号数,计算结果的商存入AX,余数存入DX。
通常,编制一个汇编语言源程序应按如下步骤进行:
1
明确任务,确定算法。
2
绘制流程图(包括确定内存单元和分配寄存器)。
3
根据流程图编写汇编语言程序。
4
上机调试程序。
5
程序的基本结构有四种:顺序结构、分支结构、循环结构和子程序结构。
6
5.6 汇编语言程序设计的基本方法
5.6.1 顺序程序设计
顺序结构也称线性结构,其特点是其中的语句或结构被连续执行。 顺序程序是最简单的,也是最基本的一种程序结构。这种结构的程序从开始到结尾一直是顺序执行的,中途没有任何分支。从这种结构的流程图来看,除了有一个起始框,一个终止框外,就是若干执行框,没有判断框。指令指针IP值线形增加,IP=IP+1
条件
N
…
例4用比较指令和条件转移指令实现两路分支的程序段。
两路分支程序设计
例4用比较指令和条件转移指令实现两路分支的程序段。 … MOV AX,M ;假定M和N为有符号数 MOV BX,N CMP AX,BX ;比较 M和N的大小,影响标志位,准备条件 JG NEXT ;M>N时转移,注意若M、N为无符号数时用JA指令 …… ;分支程序2 JMP DONE NEXT: …… ;分支程序1 …… DONE:RET
X+20 (X≥0)
汇编语言——子程序
![汇编语言——子程序](https://img.taocdn.com/s3/m/dbd62d1f650e52ea5518989d.png)
6.2.2.2 RET指令 指令 【指令格式】RET 【功能】这是子程序返回指令,必须写在子程序的指令 序列之中。根据所在的子程序的类型不同,RET指令的功能 也分为两种情况: (1)如果RET所在子程序是NEAR类型,则从堆栈中出 栈一个字(当然,SP会加2),送给IP。 (2)如果RET所在子程序是FAR类型,则先从堆栈中出 栈一个字送到IP,再出栈一个字送到CS,栈顶指SP的值加4。
cr
PROC NEAR MOV AH,2 MOV DL,13 INT 21H MOV DL,10 INT 21H RET
cr ENDP main:MOV AX,dseg MOV DS,AX LEA DX,buf MOV AH,10 INT 21H CALL cr MOV AH,1 INT 21H MOV BL,AL ;输入一个字符 ;用BL保存读入的字符 ;输入一个符号串
【解】程序段(a)中,先把AX赋值为102H,再把BX赋 值为304H,然后用ADD指令把两数相加,和为406H,结果 放在ADD指令的目的操作数AX中。 程序段(b)的前两行与(a)完全相同,AX取值102H,BX 取值304H,但在相加之前调用了子程序cr。从例6.3中cr的 具体实现方法可以知道,调用过程中寄存器AH的值被改为 2,因为INT 21H输出功能,使AL的值也被修改,变成0AH, 并且这个值一直保持到调用结束,于是“CALL cr”指令调 用子程序后,AX的值不再是调用前的102H,而变成了 20AH,当ADD指令进行两个寄存器相加时,结果是50EH, 并放到目的操作数AX中。
6.3 应用子程序进行编程
6.3.1 子程序实例
【例6.3】分析下列程序,描述它的功能。 dseg SEGMENT buf DB 80,81 DUP(0) dseg ENDS sseg SEGMENT STACK DW 64 DUP(0) sseg ENDS cseg SEGMENT ASSUME CS:cseg,DS:dseg,SS:sseg
《汇编语言程序设计》(第四版)教案及答案解析
![《汇编语言程序设计》(第四版)教案及答案解析](https://img.taocdn.com/s3/m/c9b188ee0508763231121222.png)
《汇编语言程序设计》教案附:习题参考答案《汇编语言程序设计》(第4版)钱晓捷主编前言1.汇编语言是计算机能提供给用户的最快而又最有效的语言,也是能够利用计算机所有硬件特性并能直接控制硬件的唯一语言。
2.汇编语言程序设计是高等院校电子计算机硬、软件及应用专业学生必修的核心课程之一。
它不仅是计算机原理、操作系统等其它核心课程的必要先修课,而且对于训练学生掌握程序设计技术、熟悉上机操作和程序调试技术都有重要作用。
3.本教材共有十一章,其内容安排如下:(1).第一、二章为汇编语言所用的基础知识。
(2).第三章详细介绍80x86系列CPU的指令系统和寻址方式。
(3).第四章介绍伪操作、汇编语言程序格式及汇编语言的上机过程。
(4).第五、六章说明循环、分支、子程序结构和程序设计的基本方法。
(5).第七章说明宏汇编、重复汇编及条件汇编的设计方法。
(6).第八章叙述输入/输出程序设计方法,重点说明中断原理、中断过程及中断程序设计方式。
(7).第九章说明BIOS和DOS系统功能调用的使用方法。
(8).第十~十一章分别说明图形显示、发声及磁盘文件存储的程序设计方法,同时提供各种程序设计方法和程序实例。
附:教学参考书1.沈美明、温冬婵编著,IBM–PC汇编语言程序设计(第2版),清华大学出版社,2001年(教材)2.沈美明、温冬婵编著,IBM–PC汇编语言程序设计,清华大学出版社,1991年3.沈美明、温冬婵编著,IBM–PC汇编语言程序设计—例题习题集,清华大学出版社,1991年6月4.沈美明、温冬婵、张赤红编著,IBM–PC汇编语言程序设计—实验教程,清华大学出版社,1992年5.周明德,微型计算机IBM PC/XT(0520系列)系统原理及应用(修订版),清华大学出版社,19916.郑学坚、周斌,微型计算机原理及应用(第二版),清华大学出版社,19957.王士元、吴芝芳,IBM PC/XT[长城0520] 接口技术及其应用,南开大学出版社,19908.杨素行,微型计算机系统原理及应用,清华大学出版社,19959.戴梅萼、史嘉权,微型计算机技术及应用—从16位到32位(第二版),清华大学出版社,199610.张昆藏,IBM PC/XT微型计算机接口技术,清华大学出版社,199111.孟绍光,李维星,高档微机组成原理及接口技术(80386/80486/Pentium),学苑出版社,199312.吴秀清,周荷琴,微型计算机原理与接口技术,中国科学技术大学出版社目录第 1 章基础知识 (1)1.1进位计数制与不同基数的数之间的转换 (1)1.2二进制数和十六进制数的运算 (2)1.3计算机中数和字符的表示 (3)1.4几种基本的逻辑运算 (3)第 2 章 80X86计算机组织 (4)2.180X86微处理器 (4)2.2基于微处理器的计算机系统构成 (4)2.3中央处理机 (5)2.4存储器 (6)2.5外部设备 (7)第 3 章 80X86的指令系统和寻址方式 (8)3.180X86的寻址方式 (8)3.2程序占有的空间和执行时间 (10)3.380X86的指令系统 (10)第 4 章汇编语言程序格式 (27)4.1汇编程序功能 (27)4.2伪操作 (27)4.3汇编语言程序格式 (31)4.4汇编语言程序的上机过程 (34)第 5 章循环与分支程序设计 (37)5.1循环程序设计 (37)5.2分支程序设计 (38)5.3如何在实模式下发挥80386及其后继机型的优势 (38)第 6 章子程序结构 (40)6.1子程序的设计方法 (40)6.2子程序的嵌套 (41)6.3子程序举例 (41)第 7 章高级汇编语言技术 (43)7.1宏汇编 (43)7.2重复汇编 (44)7.3条件汇编 (45)第 8 章输入/输出程序设计 (46)8.1I/O设备的数据传送方式 (46)8.2程序直接控制I/O方式 (47)8.3中断传送方式 (47)第 9 章 BIOS和DOS中断 (50)9.1键盘I/O (50)9.2显示器I/O (52)9.3打印机I/O (53)9.4串行通信口I/O (54)第 10 章图形与发声系统的程序设计 (55)10.1显示方式 (55)10.2视频显示存储器 (55)10.3EGA/VGA图形程序设计 (56)10.4通用发声程序 (57)10.5乐曲程序 (58)第 11 章磁盘文件存取技术 (59)11.1磁盘的记录方式 (59)11.2文件代号式磁盘存取 (60)11.3字符设备的文件代号式I/O (61)11.4BIOS磁盘存取功能 (62)附录:《IBM—PC汇编语言程序设计》习题参考答案 (63)第一章.习题 (63)第二章.习题 (64)第三章.习题 (65)第四章.习题 (79)第五章.习题 (84)第六章.习题 (104)第七章.习题 (118)第八章.习题 (125)第九章.习题 (130)第十章.习题 (134)第十一章.习题 (145)第 1 章 基础知识【教学目的】本章内容是本课程的基础,通过本章学习,使学生明确汇编语言程序设计的学科性质、基本内容和学习意义,掌握数制的转换、数据的编码,了解本门课程的教学要求和学习方法。
单片机——程序的基本结构
![单片机——程序的基本结构](https://img.taocdn.com/s3/m/92a8355cad02de80d4d840ea.png)
♨
✎
ORG 0000H LJMP STRAT ORG 0100H STRAT:MOV R1,#0 ; R1用于计数,R1清零 MOV DPTR,#TAB ; 设置表地址指针 GO:MOV A, R1 LOOP: MOVC A,@A+DPTR ;查表取显示码 CJNE A,#0FFH,OK ;不是结束码显示码送P0口 SJMP STRAT ;是结束码,重新开始 OK:MOV P0,A LCALL DEL ;延时1s INC R1 ;循环左移一次 SJMP GO (此处略延时程序DEL) TAB:DB 0FEH,0FDH,0FBH,0F7H,0EFH DB 0DFH,0BFH,7FH,0FFH ;LED点亮码,0FFH为结束码 .......... END
♨
✎
子程序
可以被调用的程序段称为子程序。在实际问题中,常常 会遇到在一个程序中有许多相同的运算或操作,例如多字节 的加、减、字符处理等。如果每遇到这些运算和操作,都从 头做起,则使程序非常繁琐且浪费内存。因此在实际应用中 ,通常把这些多次使用的程序段,按一定结构编好,存放在 内存中,当需要时,程序可以去调用这些独立的程序段。因
; IN为主程序或调用程序标号
┇
┇ SUB: PUSH PSW ;现场保护
PUSH ACC
子程序处理程序段 POP POP RET ACC PSW ;最后一条指令必须为RET ;现场恢复
♨
✎
【例4】编写一个通用子程序,实现N个单字节无符号数
之和(N < 100H)。调用该子程序完成将片内部30H~5FH 中存放的单字节无符号数求和,结果存入60H、61H单元 中(高位在前)。
addr11
addr16
♨
✎
汇编语言试题及参考答案
![汇编语言试题及参考答案](https://img.taocdn.com/s3/m/f75251ac82d049649b6648d7c1c708a1284a0a3d.png)
汇编语言试题及参考答案汇编语言试题及参答案一、填空题1. ZF标志位是标志结果是否为零的,若结果,ZF为(),否则ZF为()。
当ZF 为1 时,SF 为()2. 标号可以有两种类型属性。
它们是()和()3.8 位无符号整数的表示范围为0--255 ,写成16 进制形式为(),8 位有符号整数的表示范围为-128--+127, 写成16 进制形式为()4. 伪指令DB,GROUP 和NAME 三个标号名字域必须有名字的是(),不得有名字的是(),可有可无名字的是()。
5. 循环程序通常由()()()和循环结果外理四部分构成6. 在数值不达式中,各种运算符可可混合使用,其优先次序规则*,/()于+,-;XOR ,OR()于AND,LT ()于GT7. 宏指令定义必须由伪指令()开始,伪指令()结束,两者之间的语句称为()8. 调用程序与子程序之间的参数传递方法有四种,即堆栈法()()()9. 分别用一条语句实现下述指明的功能( 1 )栈顶内容弹出送字变量AYW ()(2)双字变量AYD 存放的地址指针送ES 和SI()(3)变量AY2 类型属性送AH ()( 4 )不允许中断即关中断()(5)将字符串‘ HOW ARE YOU 存入变量AYB ()( 6 )子程序返回调用程序()(7)地址表达式AYY[4]的偏移地址送字变量ADDR()(8)AX 的内容加 1 ,要求不影响CF()(9)BX 的内容加1,要求影响所有标志位()(10)若操作结果为零转向短号GOON ()二、单选题1.IBM PC 微机中,有符号数是用()表示的1 .原码2.补码3.反码4.BCD 码2. 把汇编源程序变成代码程序的过程是()1 .编译2.汇编3.编辑4.链接三、己知:VAR1 ,VAR2 的类型属性分别为字和字节,标号LPFAR 的类型属性为FAR。
指出下列非法语句的错误原因1. POP CS ()2.INC [BX] ()3. MVL 8()4. JLE LPFAR()5. MOV DB,1800()6. MOV[DI],VAR17.SUB AX,VAR2()8.CMP SS AX()四、简答题1. 试述子程序的一般结构组成2. 标号有哪三个属性?其含义是什么?3. 试述CMP AX ,BX 和SUB AX ,BX 两条语句的异同点?五、阅读如下程序段,回答所提出的问题,假定X1,X2,...XN 为无符号数。
汇编-循环与分支程序设计
![汇编-循环与分支程序设计](https://img.taocdn.com/s3/m/2b77b4bb760bf78a6529647d27284b73f24236c5.png)
方法A
MOV DL,0DH MOV AH,06H INT 21H MOV DL,0AH MOV AH,06H INT 21H
方法B
MOV DL,0AH MOV AH,06H INT 21H MOV DL,0DH MOV AH,06H INT 21H
记住以下ASCII值
退格:08H(即8) 空格:20H(即32) 换行:0AH(即10) 回车:0DH(即13) 0 :30H(即48) a :61H(即97) A :41H(即65)
程序流程图
开始
DX=A
DX=A+B BX=DX DX左移3位 BX左移1位
DX=BX+DX-500
结束
编写程序
DATA BUFA BUFB RESULT
SEGMENT DW ? DW ? DW ?
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: CODE
➢ 循环控制部分:判断循环条件满足与否,常用方法:计数控制、特 征值控制、地址边界控制等。
➢ 常用指令
[1].LOOP,LOOPZ/LOOPE,LOOPNZ/LOOPNE;
[2].各种跳转指令;
特别要注意循环入口和循环次数的正确设置、地址指针及循环控
制条件的修改等。否则会得不到期望的结果。
➢ 多重循环程序设计循环嵌套
INT 21H
不回显在屏幕上
2.键盘一次输入一个字符串的方法:
串地➢址例存如入(,DS在:D数X)据、调区用定参义数的为字10送符A缓H冲区如下:
MOV MOV MOV MOV MOV
DABADDAXuHSX,f,,,TfASAO0eEXfArGf,Hsc/eSASBo/tBEuu设TCufnGRf置BftTMfueILeNIr/frENE/fGT/设e/NN/r/置BTB/2uu/1存ffBHDffDuD功入eefBBBrrf能字是的er参符存段的33?数串放地偏22 为的输址移D0最入U存地APH大字入址(长符D存S?度串入)并的DX存缓入冲B区uffer的首字节;
简述ARM汇编语言的程序结构
![简述ARM汇编语言的程序结构](https://img.taocdn.com/s3/m/4cabb47b3d1ec5da50e2524de518964bcf84d29e.png)
简述ARM汇编语言的程序结构ARM汇编语言的程序结构,由指令、数据和指令流程控制三个主要组成部分构成。
指令是ARM汇编程序的核心,它包含了CPU指令集中的基础操作,如加、减、乘、除、移位操作等,通过这些基础操作,可以实现各种不同的功能。
指令的组成是由操作码和操作数两部分构成,其中操作码是指令的关键词汇,用于决定指令的功能,而操作数则是指令所作用的对象或数据。
数据部分是ARM汇编程序中存储、处理数据的部分。
在ARM汇编程序中,数据通常表示为二进制数值或字符,这些数据可以是程序中使用的常量,也可以是程序中间结果的计算结果。
数据的存放位置通常是通过汇编语言中的数据定义指令来实现。
指令流程控制是ARM汇编程序中控制程序执行流程的部分。
实现指令流程控制的语句包括条件分支语句、循环语句等,通过这些语句可以实现程序的条件跳转、循环执行等控制流程。
在ARM汇编程序中,指令流程控制也可以通过汇编指令的标签和跳转指令来实现。
总体而言,ARM汇编程序必须遵循一定的程序结构,包括定义全局数据段、段间跳转、异常处理等等。
ARM汇编程序的结构可以分为数据段和代码段:1. 数据段:指令流程控制之前,必须先声明所有的数据段。
数据段包括声明全局变量、局部变量、定义字符串等。
数据段只需要声明一次,不需要往返于数据段和代码段之间。
2. 代码段:代码段包括所有的指令流程控制指令。
这些指令包括从主程序跳转到子程序,从子程序返回到主程序等等。
这一部分的指令可以定义标签、跳转语句、条件分支等。
此外,在ARM汇编程序中还需要注意的一些细节,如跳转指令必须放在指令执行前面,异常处理必须考虑到所有临界条件等。
只要按照一定的结构进行编写,就可以充分发挥ARM汇编程序的性能和效率,实现各种复杂的逻辑运算和控制流程。
第四章:8086汇编语言程序设计
![第四章:8086汇编语言程序设计](https://img.taocdn.com/s3/m/b7991e36f111f18583d05a24.png)
第 4章
汇编语言程序设计
汇编语言程序设计
(2)尽量采用循环结构和子程序 (2)尽量采用循环结构和子程序 采用循环结构和子程序可以使程序的长度减少、 采用循环结构和子程序可以使程序的长度减少、 占用内存空间减少。 占用内存空间减少。 多重循环,注意各重循环的初值和循环结束条件, 多重循环,注意各重循环的初值和循环结束条件, 死循环”现象; 避免出现 “死循环”现象; 通用的子程序, 通用的子程序,除了用于存放子程序入口参数的寄 存器外, 存器外,子程序中用到的其它寄存器的内容应压入堆栈 进行现场保护, 进行现场保护,并要特别注意堆栈操作的压入和弹出的 平衡; 平衡; 中断处理子程序除了要保护程序中用到的寄存器外, 中断处理子程序除了要保护程序中用到的寄存器外, 还应保护标志寄存器。 还应保护标志寄存器。
1、汇编语言的语句格式
汇编语言源程序是由汇编语句(即指令)组成的。 汇编语言源程序是由汇编语句(即指令)组成的。 汇编语言一般由四部分组成。 汇编语言一般由四部分组成。
其典型的汇编语句格式: 其典型的汇编语句格式: 标号: 标号:操作码
例如: 例如: START: START:MOV AL,30H AL,30H ;(AL)=30H (AL)=30H 30
第 4章
汇编语言程序设计
汇编语言程序设计
经过任务分析、算法优化后, 经过任务分析、算法优化后, 在微型机上使用编 首先, 首先,要对单片机应用 就可以进行程序的总体构思, 就可以进行程序的总体构思, 辑软件编写源程序, 辑软件编写源程序, 系统预完成的任务进行 确定程序的结构和数据形式, 确定程序的结构和数据形式, 在使用交叉汇编的 深入的分析, 深入的分析,明确系统 并考虑资源的分配和参数的 方法对源程序进行 的设计任务、 的设计任务、功能要求 计算等。 计算等。然后根据程序运行 汇编, 汇编,然后采用串 和技术指标。其次, 和技术指标。其次,要 的过程, 的过程,勾画出程序执行的 算法是解决具体问题 行通信的方法, 行通信的方法,把 对系统的硬件资源和工 逻辑顺序, 。同一个问题 逻辑顺序,用图形符号将总 的方法。 的方法 汇编得到的目标程 作环境进行分析。 ,, 作环境进行分析。这是 体设计思路及程序流向绘制 的算法可以有多种, 的算法可以有多种 序传送到单片机内, 序传送到单片机内 单片机应用系统程序设 在平面图上, 在平面图上,从而使程序的 结果也可能不尽相同, 结果也可能不尽相同, 并进行程序运行和 计的基础和条件 结构关系直观明了, 结构关系直观明了,便于检 所以, 调试 所以,应对各种算法 查和修改。 查和修改。 进行分析比较,并进 进行分析比较, 行合理的优化
汇编语言的基本语法
![汇编语言的基本语法](https://img.taocdn.com/s3/m/f92bfbbe998fcc22bcd10d58.png)
再例如,对如下的定义,
W1 DW 1, 2, 3, 4, 5, 6, 7 B1 DB 10, 20, 30, 40, 50
N1 EQU B1-W1
N2 EQU $-W1
B2 DB 0 则N1=14,它是从W1开始到B1前为止的一组变量的字节
数; N2=19,它是从W1开始到B2($代表的地址)前为止的一组
PROC NEAR(或FAR) ____________
____________
. . . ____________ RET ENDP
(6) 偏移地址计数器$
汇编程序在对源程序进行汇编的过程中,用偏移地址计数 器$来保存当前正在汇编的指令的偏移地址或伪指令语句 中变量的偏移地址。
用户可将$用于自己编写的源程序中。
例: A DB 20H,30H ; 注释
指令语句是可执行语句,其格式为:
[名字:]指令操作助记符[操作数表达式1[,操作数表达式2]][;注释]
其中,指令操作助记符(指令名)是指令语句中不可缺少的 主体,其余部分(方括号中的内容)有时可省略。
名字只能是标号。 注释以分号开头,分号右边的内容将被汇编程序忽略。 例 L: ADD AX,BX ;注释
汇编后:
第一个$+4:$+4=(A+4)+4=(0074H+4)+4=007CH 第二个$+4:$+4=(A+10)+4=(0074H+0AH)+4=0082H
在指令中,$无论出现在指令的任何位置,都代表本条指 令第一个字节的偏移地址。例如,“JZ $+6”的转向地址 是该指令的首地址加上6,$+6还必须是另一条指令的首地 址。再如,在下述指令序列中,
汇编语言第5章王爽版(子程序调用指令)
![汇编语言第5章王爽版(子程序调用指令)](https://img.taocdn.com/s3/m/186e73a56037ee06eff9aef8941ea76e58fa4a95.png)
例5-1:分别用三种参数传递方法编写求1+2的和的程序。要求将结果送到内存单元,并显示。
DATA SEGMENT SUM DB 0 DATA ENDS STACK SEGMENT DB 100 DUP(?) STACK ENDS CODE SEGMENT ASSUME DS:DATA,SS:STACK,CS:CODE START: MOV AX,DATA MOV DS,AX MOV AL, 1 MOV BL, 2 CALL subprog mov ah,4cH int 21h CODE ENDS END START
5.2 子程序的定义、调用和返回(续)
子程序返回指令(RET)
RET [n] 功能:弹出CALL指令压入堆栈的返回地址 段内返回——偏移地址IP出栈 IP←SS:[SP], SP+2 段间返回——偏移地址IP和段地址CS出栈 IP←SS:[SP],SP←SP+2 CS←SS:[SP],SP←SP+2
子程序的概念
子程序的现场保护与参数传递**
子程序的嵌套与递归调用
子程序的定义、调用和返回 **
子程序设计 *
宏汇编程序设计
教学基本内容
第5章 结构化程序设计
子程序:在程序设计中,我们会发现一些多次无规律重复的程序段或语句序列。解决此类问题一个行之有效的方法就是将它们设计成可供反复调用的独立的子程序结构,以便在需要时调用。在汇编语言中,子程序又称过程。 过程(子程序):是指功能相对独立的一段程序。 主程序和子程序间的关系:调用子程序的程序称为主调程序或主程序,被调用的程序称为子程序。
Spr PROC PUSH BP MOV BP, SP MOV AX, [BP+6] MOV BX, [BP+4] ADD AL, BL OR AL, 30H MOV DL,AL MOV AH,2 INT 21H MOV SUM, AL POP BP RET Spr ENDP
汇编语言程序格式
![汇编语言程序格式](https://img.taocdn.com/s3/m/4f7f3399783e0912a3162a56.png)
1.2汇编语言程序的段定义
DATA_SEG1 SEGMENT PARA
DATA_SEG1 ENDS
DATA_SEG2 SEGMENT PARA
…….
DATA_SEG2 ENDS
E_SEG1
SEGMENT PARA
……..
ቤተ መጻሕፍቲ ባይዱ
E_SEG1
ENDS
E_SEG2
SEGMENT PARA
……..
E_SEG2
ENDS
ENDP 说明:过程属性项省略,系统默认为NEAR,表示段内调用, FAR 过程体至少有一条返回指令RET,RET一般放在过程体的最后。 也可以使用带参数的返回语句,如RET n。
1.3汇编语言源程序过程定义
MY_CODE SEGMENT
UP_COUNT PROC NEAR
ADDCX, 1
RET
UP_COUNT ENDP
1.2 汇编语言程序的段定义
存储器是采用分段管理方式,在编制任意源程序时亦必 须按段来构造程序。按段来构造程序有两种形式:一种是完
1.
NAME TITLE EQU EXTRN PUBLIC SEG1
SEG1 SEG2
SEG2
SEGMENT PARA STACK …… ENDS SEGMENT PARA STACK ; …… ENDS
避免多模块使用不同起始地址,只有主模块使用起始地址, 否则引起程序出错。
1.4标准程序前奏
Code_SREG1 SEGMENT‘CODE’ ASSUME CS:Code_SREG1…
MAIN PROC FAR ……… RET
MAIN ENDP Code_SREG1 ENDS
END MAIN Code_G2 SEGMENT ‘CODE’
汇编语言——子程序
![汇编语言——子程序](https://img.taocdn.com/s3/m/dbd62d1f650e52ea5518989d.png)
M
【解】 (1)当计算机把CALL subp对应的机器指令取到CPU中 时,IP的值已经是CALL的下一行的MOV指令所在的偏移地 址5678H,此时还未进栈,栈的情况如图6.3(a)所示。 (2)由于子程序subp是NEAR类型,按照CALL指令功能 的第一种情况执行CALL指令,把IP的值入栈,并把IP的值改 为subp子程序的入口地址1234H,此时堆栈的情况如图6.3(b) 所示。 (3)执行完CALL指令 IP的值已经变成1234H,CS没变, CPU按新的IP值,在CS段下取出一条指令,即INC AL指令。
【例6.2】分析下面的程序段的执行过程,以及在执行过 程中堆栈及指令指针IP的变化情况,并假设在执行CALL指令 前,SP的值是0FEH。 subp PROC INC NEAR AL ;假设本指令所在的偏移地址是1234H
M
RET subp ENDP
M
CALL MOV 5678H subp AX,BX ;假设本指令所在的偏移地址是
M
子程序2 ENDP
M
子程序n PROC NEAR
M
子程序n ENDP 入口标号: M 段名 ENDS
从入口标号起的程序段是主程序。RET指令必须出现在子 程序中,而CALL指令可以出现在代码段的任何地方。主程序 可以调用子程序,一个子程序可以调用另一个子程序,还可 以调用它自身,并且在书写次序上没有“先定义后调用”的 限制。 源程序中的指令段在经过汇编程序的翻译后,所有伪指 令都不存在了。作为CALL指令的操作数,“子程序名”部分 会翻译成子程序第一条指令的逻辑地址。当计算机在执行 CALL 指令时,CS和IP已经是下一条指令的逻辑地址。CALL 指令具有保存当前IP或者CS和IP并修改它们的值的能力,因 此CALL执行完后,会按照新的CS及IP,转去执行子程序的第 一条指令,并依次执行后续指令,完成子程序的功能,直至 遇到RET指令。RET指令的执行效果是从栈中取出由CALL保 存的数据,恢复在执行CALL指令时的IP或者CS与IP值,从而 回到CALL指令的下一行继续执行。
汇编语言结构
![汇编语言结构](https://img.taocdn.com/s3/m/f2be1a00326c1eb91a37f111f18583d048640f41.png)
汇编语言结构汇编语言是一种低级别的编程语言,用于与计算机硬件进行直接交互。
它提供了对计算机硬件的底层访问和控制,使程序员能够更加精确地编写处理器指令。
一、概述汇编语言结构是汇编程序的基本组成部分。
一个典型的汇编程序由若干条指令组成,每条指令执行特定的操作。
指令通常包括操作码和操作数,用于指定要执行的任务和相关数据。
在编写汇编程序时,程序员需要了解指令的结构和格式,以正确地编写代码。
二、指令格式在汇编语言中,每条指令都有固定的格式,即操作码、目标操作数和源操作数。
操作码指定要执行的操作类型,目标操作数用于存储操作结果,源操作数用于提供操作所需的数据。
根据不同的指令类型,操作数的格式和长度也会有所不同。
三、寄存器寄存器是汇编语言中的一种重要数据存储单位,用于存储和处理数据。
计算机硬件通常提供了各种类型的寄存器,如通用寄存器、标志寄存器和指令指针寄存器等。
在编写汇编程序时,程序员可以使用这些寄存器来完成各种任务,如存储数据、进行运算和控制程序流程等。
四、内存内存是计算机中的一种重要存储设备,用于存储程序和数据。
在汇编语言中,程序员可以使用内存来存储变量、数组和其他数据结构,以便在程序执行过程中进行读写操作。
为了有效地使用内存,程序员需要了解内存的地址和访问方式等相关知识。
五、程序结构汇编语言程序通常由若干个过程和子程序组成,用于实现特定的功能。
程序员可以使用标签和跳转指令来控制程序的流程,实现条件分支和循环等结构。
此外,程序员还可以使用宏指令来简化代码编写和调试过程,提高程序的可读性和可维护性。
六、汇编程序的工具和环境为了编写和调试汇编程序,程序员通常需要使用汇编器和调试器等工具。
汇编器用于将汇编源代码翻译成机器码,调试器用于辅助程序员进行代码调试和错误排查。
此外,程序员还可以使用集成开发环境(IDE)来提供更加友好和便捷的编程环境。
结论汇编语言是一种强大而灵活的编程工具,可以直接操作计算机硬件。
通过了解汇编语言的结构和格式,程序员可以编写高效和可靠的代码,更好地理解计算机的工作原理。
汇编语言程序
![汇编语言程序](https://img.taocdn.com/s3/m/da98690ab52acfc789ebc96f.png)
方法三:采用同#0FH、#0F0H相与的方法分离 高低4位,将两个BCD数分开。 ORG 1000H MOV A,20H ANL A,#0FH ORL A,#30H MOV 22H,A MOV A,20H ANL A,#0F0H SWAP A ORL A,#30H MOV 21H,A;9条指令,17个字节,9个机 器周期;
第五章 汇编语言程序设计 1 程序设计方法 2 顺序程序 3 4 5 6 分支程序 循环程序 子程序 位操作程序
1、本章教学内容: (1)汇编应用概述 (2)简单程序设计 (3)分支程序 (4)循环程序 (5)查表程序 (6)子程序的设计及其调用
(7)位操作程序
2、本章基本要求 (1)掌握简单程序设计 (2)掌握分支和散转程序设计 (3)理解循环程序 (4)掌握简单查表程序 (5)掌握子程序的设计、位操作
程序
5-1-2 汇编语言程序设计步骤
一、 分析问题,建立数学模型。 二、确定算法:对待定问题求解步骤的一种描 述,是指令的有限集合,算法有五个特征: 有穷性、确定性、可行性、输入、输出 开始 三、制定程序流程图: 表示程序结构和程序功能
?
N
Y
1
四、编制源程序 1.确定数据结构:合理分配存储器单元和了 解I/O接口地址。 2.按功能设计,明确各程序之间关系。 3.用注释行说明程序。 生成一个ASCII码文件,扩展名为“.ASM”。
方法2 相对地址表PRGTBL:DB PRGi-PRGTBL 决定地址表长加分支处理程序长小于256B. 方法3:跳转表+散转指令 例 5 - 1 0 1 2 8 路 分 支 程 序 。 功 能 : 根 据 R3 的 值 (00H~7FH)转到128个目的地址。 参考程序:
JMPl28:MOV A,R3 RL A ;(A)×2 MOV DPTR,#PRGTBL ;散转表首址 JMP @A+DPTR ;散转 PRGTBL:AJMP ROUT00 AJMP ROUT01 … AJMP ROUT7F ;128个AJMP指令占 RORT00: … ROUT01 : … 注意:通过AJMP跳到各分支,限制分支程序入口 RORTi必须于对应AJMP指令在同一2KB范围。
汇编语言I/O子程序库设计
![汇编语言I/O子程序库设计](https://img.taocdn.com/s3/m/e8608183680203d8ce2f2494.png)
DS MS 显示字符 串 ( IP G 以0结尾 ) D S C 显示 一个字符 IP
子程序 ,简化 了子程序 的代 码编 写 ,减少 了子程序 库的长
度 。主 要 子 程 序 之 间 的关 系 如 图 1 示 。 所
串转换为不同数制的数据 ,从而 实现 了不 同数 制输入 的子
程 序 R A BN、 E D E R A U 、 E D I ; 过 调 用 E D I R A H X、 E D IR A S 等 通
设 计 的 13子 程 序 库 包 括 1 版 本 和 3 , 1 6位 2位 版 本 , 分 可 别 应 用 于 1 和 3 汇 编 语 言 应 用 程 序 ,提 供 的 子程 序 6位 2位
功能包括不 同数制和字 符串的输 入与显示 ,状态标 志的显
示 , 足 汇编 语 言 程 序 设 计 的 通 常 要 求 。 满
1设计方案
11 子 程序 功 能 需求 .
根据在汇编语 言程序设计 中的通 常要 求,子程序所提
供 的 功 能 主要 包 括 键 盘 输 入 和 显 示 器 显 示 , 输 入 和 显 示 的
图 1主要子程序之间的关 系 字 符 输 入 和 显 示 子 程 序 R A C DS C是 整 个 子 程 序 E D 、 IP 库输 入输 出的基础 。利 用这 两个子程序实现 了字符 串输入
1 参 数 传 递 . 3
D S U 显示无符号十进制整数 IP I
t e o t u t g o h o sl . h u p t n n t e c n o e i Ke wo d As e l a g a e y r: s mb y L n u g I O / P oe ue rc d r L bay irr
第4章-汇编语言程序设计教案
![第4章-汇编语言程序设计教案](https://img.taocdn.com/s3/m/cfca74a18ad63186bceb19e8b8f67c1cfad6ee25.png)
第四章教学实施计划3课堂教学实施计划第 8 课教学过程设计:复习 0 分钟;授新课 100 分钟讨论 0 分钟;其它 0 分钟授课类型(请打√):理论课√讨论课□实验课□习题课□其它□教学方式(请打√):讲授√讨论□示教□指导□其它□教学手段(请打√):多媒体√模型□实物□挂图□音像□其它□4.1 汇编语言程序设计概述程序实际上是一系列计算机指令的有序集合。
我们把利用计算机的指令系统来合理地编写出解决某个问题的程序的过程,称为程序设计。
程序设计是单片机应用系统设计的重要组成部分,单片机的全部动作都是在程序的控制下进行的。
随着芯片技术的发展,很多标准的或功能型的硬件电路都集成到了芯片中,所以,软件设计在单片机应用系统开发中占的比重越来越大。
一、汇编语言和高级语言汇编语言:用助记符表示的指令称为汇编语言,用汇编语言编写的程序称为汇编语言源程序汇编语言也是面向机器的,它仍是一种低级语言。
汇编语言离不开具体计算机的硬件,与硬件紧密相关。
高级语言:高级语言不受具体“硬件”的限制,具有通用性强,直观、易懂、易学,可读性好等优点。
多数的51单片机用户使用C语言来进行程序设计。
C语言已经成为人们公认的高级语言中高效、简洁而又贴近51单片机硬件的编程语言。
二、汇编语言的特点•助记符指令和机器指令一一对应,所以用汇编语言编写的程序效率高,占用存储空间小,运行速度快,因此汇编语言能编写出最优化的程序。
•使用汇编语言编程比使用高级语言困难,因为汇编语言是面向计算机的,汇编语言的程序设计人员必须对计算机硬件有相当深入的了解。
•汇编语言能直接访问存储器及接口电路,也能处理中断,因此汇编语言程序能够直接管理和控制硬件设备。
•汇编语言缺乏通用性,程序不易移植,各种计算机都有自己的汇编语言,不同计算机的汇编语言之间不能通用。
三、汇编语言的语句格式•指令语句:每一条指令语句在汇编时都产生一个指令代码(也称机器代码),执行该指令代码对应着机器的一种操作。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
子程序结构
过程定义伪操作 子程序的调用与返回 保存与恢复寄存器 子程序的参数传送 子程序的嵌套与递归
1
1. 过程定义伪操作
过程名 PROC . . .
过程名 ENDP (1)NEAR属性:调用程序和子程序在同一代码段中 (段内调用) (2)FAR属性:调用程序和子程序不在同一代码段中 (段间调用)
bp bp, sp
ax cx si di si,[bp+0ah] di,[bp+8] cx,[di] di,[bp+6]
ax, [si] si, 2 next [di],ax di si cx ax bp 6 endp
(di) (si) (cx) (ax)
(bp) (bp) (ip)
(cs) (bp)+6 sum
(1) 通过寄存器传送参数 (2) 通过存储器传送参数 (3) 通过地址表传送参数地址 (4) 通过堆栈传送参数或参数地址 (5) 多个模块之间的参数传送
6
例:十进制到十六进制的转换(通过寄存器传送参数)
参 数 传 递 方 法 1
decihex SEGMENT ASSUME CS:decihex main proc far start: call decibin call crlf call binihex call crlf mov ah,1 int 21h cmp al,27 jnz start mov ah,4ch int 21h main endp decihex ENDS END start
next:
proc
push push push lea mov xor add add loop mov pop pop pop ret
near
ax cx si si, ary cx, count ax, ax ax, [si] si, 2 next sum,ax si cx ax
参 数 传 递 方 法 2
14
code2 segment assume cs:code2 proadd proc far xor next: add add loop mov pop pop pop pop pop ret ax, ax
(sp)
push mov
push push push push mov mov mov mov
next:
10d 0000 (si) 20d 30d 40d 50d 60d 70d 80d 90d 100d count 10d 0014 sum 550d 0016 (di) table 0000 0018 (bx) 0014 0016
ary
proadd code
ห้องสมุดไป่ตู้
main
12
例:累加数组中的元素(通过堆栈传送参数地址)
8
例:累加数组中的元素(通过存储器传送参数)
data segment ary count sum data ends code segment main proc assume Start: mov mov call dw dw dw 1,2,3,4,5,6,7,8,9,10 10 ? proadd far cs:code,ds:data ax, data ds, ax proadd
data code main
参 数 传 递 方 法 3
main
11
proadd
proc push push push push mov mov mov mov xor add add loop mov pop pop pop pop ret endp ends end
near ax cx si di si, [bx] di, [bx+2] cx, [di] di, [bx+4] ax, ax ax, [si] si, 2 next [di],ax di si cx ax
(bp)+8 count (bp)+0ah array
tos
code2
ends end start
proadd
15
ends segment
…… far ptr subt ……
segy
call
code ends
segy
ends
3
2. 子程序的调用与返回
子程序调用:隐含使用堆栈保存返回地址 call near ptr subp
(1) 保存返回地址 (2) 转子程序
(SP)→
(IP)
call far ptr subp
2
NEAR ( FAR )
code segment
main proc …… call …… ret endp far subr1
segx
subt
segment
proc …… ret endp …… subt …… far
subt call
main
segx
subr1 proc …… ret subr1 endp near
data segment ary dw 10,20,30,40,50,60,70,80,90,100 count dw 10 sum dw ? ends
data
参 数 传 递 方 法 4
stack segment dw 100 tos label stack ends
dup (?) word
13
code1 segment main proc far assume cs:code1, ds:data, ss:stack start: mov ax, stack mov ss, ax mov sp, offset tos mov ax, data mov ds, ax mov bx, offset ary push bx mov bx, offset count push bx mov bx, offset sum push bx call far ptr proadd mov ax, 4c00h int 21h main endp code1 ends
(1) 保存返回地址 (2) 转子程序
(SP)→
(IP) (CS)
子程序返回:ret
4
3. 保存与恢复寄存器
subt proc
push push push push …… …… pop pop pop pop
ret
far
ax bx cx dx
dx cx bx ax
subt
endp
5
4. 子程序的参数传送
7
decibin proc near mov bx,0 newchar:mov ah,1 int 21h sub al,30h jl exit cmp al,9d jg exit cbw xchg ax,bx mov cx,10 mul cx add bx,ax jmp newchar exit: ret decibin endp
10,20,30,40,50,60,70,80,90,100 10 ?
如果直接访问内存变量,那么累加数组ary 和数组ary1中的元素不能用同一个子程序 proadd。
10
例:累加数组中的元素(通过地址表传送参数地址)
data segment ary dw 10,20,30,40,50,60,70,80,90,100 count dw 10 sum dw ? table dw 3 dup (?) ; 地址表 ends segment proc far assume cs:code, ds:data push ds sub ax, ax push ax mov ax, data mov ds, ax mov table, offset ary mov table+2, offset count mov table+4, offset sum mov bx, offset table call proadd ret endp
main
mov int endp
ax,4c00h 21h
code
ends end
start
proadd
endp
9
如果数据段定义如下:
data segment
ary count sum ary1 count1 sum1
data ends
dw dw dw dw dw dw
1,2,3,4,5,6,7,8,9,10 10 ?
binihex proc near mov ch,4 rotate: mov cl,4 rol bx,cl mov al,bl and al,0fh add al,30h cmp al,3ah jl printit add al,7h printit:mov dl,al mov ah,2 int 21h crlf proc near dec ch mov dl,0dh jnz rotate mov ah,2 ret int 21h binihex endp mov dl,0ah mov ah,2 int 21h ret crlf endp