微机原理_汇编语言学习.ppt

  1. 1、本文档共95页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机原理_汇编语言学习

微型计算机原理及应用;第三章 汇编语言程序设计;§3.1 汇编语言基本元素; 由汇编语言编写的源程序是由许多语句(也可称为汇编指令)组成的。每个语句由1~4个部分组成,其格式是: [标识符] 指令助记符 [操作数][;注解];(1)标识符:给指令或某一存储单元地址所起的名字。 标识符由下列字符组成:(以字母或圆点开头) 字母: A~Z, a~z; 数字: 0~9; 特殊字符: ? . @ _ $;(2)指令助记符 表示不同操作的指令,可以是8086/8088的指令助记符,也可以是伪指令。 ;汇编语言运算符:是汇编程序在汇编时计算的,与运算指令不同,指令是在程序运行时计算的。 1、算术运算符、逻辑运算符、关系运算符 如:+、-、×、 / 、 AND、OR、LT等 MOV AX, [DI+BX] ADD AX, FIRST+1 MOV AX, ((choice LT 20) AND 5) OR ((choice GE 20) AND 6 ) ;注意: 算术运算符总可以用于数字操作,其结果也是数字的。当应用于存储器操作数时,只有+, -运算符有意义; 逻辑运算符的操作数也必须是数字,存储器操作数不能进行逻辑运算; 关系运算符连接的两个操作数,必须都是数字的或是在同一段内的存储器地址。;2、取值运算符 1) $运算符 $:当前地址偏移量的值;SEG 和OFFSET SEG: 求标号或变量的段地址 OFFSET: 求标号或变量的偏移地址;3) TYPE 返回标号或存储器操作数的类型值 对存储器操作数:表示占用的字节数 对标号:表示过程或指令地址的调用类型;4) LENGTH 和 SIZE(对用DUP定义数据的情况下);3、属性运算符;3.1.3 表达式;1、 常数;2、常量操作数;3、存储器操作数;存储器操作数有三个属性;DATA SEGMENT X DB 5, 4 Y DW 40H Z DD 2030H DATA ENDS;4、常量表达式;5、地址表达式;3.1.4 汇编语言程序汇编步骤;.ASM;用户编写程序,程序在计算机中运行,计算机的控制由操作系统交给用户程序,运行用户程序,当用户程序运行结束后,应再将控制权交回操作系统,所以,在程序中应该有返回DOS的操作。在计算机中,返回DOS的操作由操作系统中的一个子程序来实现,用户使用时调用这个子程序即可。;每当一个用户的可执行文件.EXE装入内存后,存储器的分配情况如图:;系统占用;如何使用户程序执行完后返回来执行这条指令?;返回操作系统的另一个办法是通过系统调用(调用号是4CH)。这时, 在用户程序结束时,用下面两条指令: MOV AH, 4CH INT 21H 即可实现返回DOS。;§3.2 伪指令;伪指令:伪指令不是CPU运行的指令,而是程序员给汇编程序下达的命令。是在汇编源程序期间由汇编程序执行的命令。;3.2.1 数据定义伪指令;若仅保留单元,不初始化,用?代替初值; 若数据重复,用 n DUP( )代替,n为重复次数。;例:有如下数据定义伪指令: VAL DB 1,4 DUP (5, 2 DUP(FFH, 0 )) 则在VAL存储区前10个字节单元的数据是:;3.2.2 符号定义伪指令;DATA SEGMENT A DW 3 B DW 4 L EQU B-A DATA ENDS;3.2.3 段定义伪指令SEGMENT和ENDS;1)段名必须是合法的标识符。;每16个地址为一段(PARA), 每段的起始地址为二进制: **** **** **** **** 0000 16进制:****0H ;每2个地址为一个字(WORD),每个字的起始地址为偶数; 最基本的类型是字节(BYTE),每个字节只包含一个地址,可以是内存的任何空间。;3)组合类型;COMMON: 表示产生一个覆盖段。连接时,把本段与其他也用COMMON说明的同名段置成相同的起始地址,重叠在一起,共享相同的存储区,其段长度由最长的段确定。;MEMORY: 表示本段在存储器中应定位在所有其他段的最高地址。;4) 类别;3.2.4 设定段寄存器伪指令ASSUME;注意:;3.2.5 过程定义伪指令PROC和ENDP;一个码段中可以包含一个或许多过程。过程可以嵌套调用,可以递归调用,但不可以嵌套定义。;例:延时100ms的子程序,编程定义如下:;在汇编语言书写的源程序中,有的

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档