8086汇编语言基础学习(三)——伪指令

8086汇编语言基础学习(三)——伪指令8086汇编语言基础学习(三)——伪指令什么是伪指令:定义:伪指令(PseudoInstruction)是用于对汇编过程进行控制的指令,该类指令并不是可执行指令,没有对应机器代码,只用于汇编过程中为汇编程序提供汇编信息。特点:“伪”,假指令,是不可以执行的指令,没有对应的机器代码,不会占

大家好,欢迎来到IT知识分享网。

8086汇编语言基础学习(三)——伪指令

什么是伪指令:

定义:

  • 伪指令(Pseudo Instruction)是用于对汇编过程进行控制的指令,该类指令并不是可执行指令,没有对应机器代码,只用于汇编过程中为汇编程序提供汇编信息。

特点:

  • “伪”,假指令,是不可以执行的指令,没有对应的机器代码,不会占用ROM空间,只用于汇编过程中为汇编程序提供汇编信息
  • “指令”,只存在于汇编语言中,高级语言中不叫指令,叫语句

区别:

  • 指令是在执行阶段发挥作用的,由CPU来执行
  • 伪指令是在编译阶段发挥作用的,由汇编器来解释

数据定义类伪指令:

为源程序中的数据和堆栈分配存储单元是,使用的伪指令

格式:

  • [ <变量名> ]  <类型><初值表>

数据类型:

  • DB(定义字节)一个字节数据占用1个字节的存储单元,读操作时,偏移量加1
  • DW(定义字)一个字数据占用2个字节的存储单元,读操作时,偏移量加2
  • DD(定义双字)一个双字数据占用4个字节的存储单元,读操作时,偏移量加4
  • DQ(定义四字)一个四字数据占用8个字节的存储单元,读操作时,偏移量加8
  • DT(定义十字)常用于BCD码

初值:

  • 可以是常数、表达式、字符串

符号定义类伪指令:

符号定义伪指令是给一个数值、字符串或表达式赋予一个名字。符号定义伪指令有等值伪指令EQU、等号伪指令 “=”、符号 / 标号伪指令LABEL三种,其实是给内存地址一个标号

1. EQU(等值伪指令)

  • 格式:<符号名> EQU <表达式>

8086汇编语言基础学习(三)——伪指令

 

8086汇编语言基础学习(三)——伪指令

 

8086汇编语言基础学习(三)——伪指令

 2. “=” 伪指令

  • 格式:<符号名> = <表达式>

8086汇编语言基础学习(三)——伪指令

  •  区别:
    • EQU伪指令定义的符号在一个源程序中是不能被重复定义的
    • ”=“伪指令定义的符号可以被重复定义,但是后定义的符号变量会覆盖前者的定义
    • 使用EQU伪指令定义的符号名不仅可以代表某个常数或常数表达式,还可以代表字符串、关键字、指令码、一串符号(如WORD PTR)等,而使用等号伪指令定义的符号名仅用于代表数值表达式。

3. LABEL伪指令

  • 描述:符号定义伪指令和THIS运算符(关于表达式中的运算发的讲解在之后)功能类似,可以为当前存储单元定义一个指定类型的变量或标号。
  • 格式:<符号名>  LABEL <表达式>,其中,数据类型就是常用的数据类型:BYTE、WORD、DWORD、结构类型、记录类型(这五类符号名就是变量名)NEAR、FAR(这两类符号名就是标号名)等。

8086汇编语言基础学习(三)——伪指令

 

8086汇编语言基础学习(三)——伪指令

 段和过程定义伪指令:

段和过程定义伪指令用来定义代码段、数据段、堆栈段和子程序。

1.段定义伪指令

  • 描述:为了与存储器的分段结构相对应,汇编语言源程序也是用分段的方法来组织程序代码、数据和变量的。段定义伪指令SEGMENT/ENDS用于段的定义
  • 格式:

8086汇编语言基础学习(三)——伪指令

    • 段名:给段起的名字,这是必须的属性,定位类型,组合类型,’类别‘是可选属性,初学时最好默认!!
    • 定位类型:确定逻辑段的起始地址:BYTE, WORD, PARA, FAGE, 默认是PARA(节),低四位地址为0
    • 组合类型:说明逻辑段装入内存时如何和其他段进行组合,有NONE, PUBLIC, STACK, COMMON, MEMORY, AT六种:
    1. NONE,为默认值,表示本段和其他段不发生关系,具有独立的段地址
    2. PUBLIC:将同名同类型的段相邻地连接到一起,具有共同的段地址。
    3. STACK:和PUBLIC功能一样,但用于堆栈段,定义堆栈段必须有
    4. COMMON:所有同名同类型段具有相同段地址,但后面的会覆盖前面的,用于共享数据。
    5. MEMORY:将本段定义在其他段之后。
    6. AT :将本段定义在表达式指定位置,但代码段不能用。
    • 类别:用户自定义的类别名,用单引号括起来,如’STACK’,’CODE’,’DATA’。连接程序会把类别名相同的所有段装入内存的连续区域

8086汇编语言基础学习(三)——伪指令

  •  注意:如果用户不自己定义堆栈段,程序就会默认使用系统的堆栈段,有大量的入栈数据时要定义自己的堆栈。初始化程序时要使用MOV指令初始化SS和SP。(似乎加上STACK组合类型就可以省去初始化操作)

2. 假定伪指令

  • 描述:假定伪指令用在代码段中,它用来告诉汇编程序,如何设定各段与对应段寄存器的映射关系
  • 格式:ASSUME  <段寄存器名> : <建立映射的段名>, <段寄存器名> : <建立映射的段名>, ……。段寄存器名可以是CS、DS、ES或SS,段名则是由段定义伪指令定义。
  • 注意:
    • 段名可以时一个特别关键字NOTHING,表示某个段寄存器不在与任何段有关系。
    • 假定伪指令通常在代码段的起始就使用(暂不确定)

 3.  过程定义伪指令

  • 描述:可将具有一定功能的程序段看成一个过程(相当于一个子程序)。它可以被其他程序调用(用CALL指令)转移到这段程序执行,执行完再返回主程序。
  • 格式:

8086汇编语言基础学习(三)——伪指令

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/30556.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信