汇编语言-读书知识点记录

汇编语言:汇编指令,伪指令,其他符号

【CPU读写需要三个要素】:存储单元的地址(地址信息);器件的选择,读或写的命令(控制信息);读或写的数据(数据信息)

【存储器分类】:

  • 随机存储器(主板上的RAM和插在扩展插槽上的RAM)
  • 装有BIOS的ROM,主板上的BIOS(系统BIOS)和接口卡上的BIOS(如显卡和网卡上的BIOS)
  • 接口卡上的RAM(如显存)
  • 【总线分类】内部总线实现CPU内部各个器件之间的联系,外部总线实现CPU和主板上其他器件的联系


    通用寄存器:AX,BX,CX,DX 可以分为高位和低位,例如AX可以分为AH和AL

    偏移地址为16位,16位地址的寻址能力位64KB,所以一个段的长度最大为64KB

    段寄存器:CS,DS,SS,ES
    CS和IP:代码段寄存器和指令指针寄存器

    【8086CPU的工作过程】:

  • 从CS:IP指向的内存单元读取指令,读取的指令放入指令缓存器
  • IP=IP+所读取指令的长度,从而指向下一条指令
  • IP=IP+所读取指令的长度,从而指向下一条指令
  • 执行指令。转到步骤1,重复。
  • 【jmp 段地址:偏移地址】:用指令中给出的段地址修改CS,偏移地址修改IP
    【jmp 寄存器】:用寄存器中的值修改IP

    【debug】

  • -r:查看CPU中各个寄存器中的内容
  • -r reg:查看并修改某个寄存器的内容
  • -d:查看内存中的内容(128个字节)
  • -u:查看内存中的汇编指令
  • -e:改写内存中的内容
  • -t:执行CS:IP的指令
  • -a:以汇编指令的形式在内存中写入机器指令
  • 8086CPU中有一个DS寄存器,通常用来存放要访问数据的段地址。

        mov bx, 1000H
        mov ds, bx
        mov al, [0]

    上述指令会将1000:0中的数据读到al中,8086CPU不支持将数据直接送入到段寄存器

    mov reg, data
    mov reg, reg
    mov reg, mem
    mov sreg, mem
    mov mem, reg
    mov sreg, reg
    mov reg, sreg

    段寄存器SS和寄存器SP,【debug】的T命令在执行修改寄存器SS的指令时,下一条指令也会紧接着被执行。

    可执行文件包括两部分内容:程序和数据, 相关的描述信息

    伪指令

    XXX segment
        :
        :
    XXX ends
    段可以用来存放代码,数据或者当作栈空间
    end
    汇编程序的结束标记
    assume
    将某一段寄存器和程序中的某一个使用segment...ends的段相关联,例如assume cs:codesg

    程序:由计算机执行,处理的指令或数据

    标号:段名称,最终会被编译,链接程序处理为一个段的段地址,如codesg
    程序返回:

        mov ax,4c00H
        int 21H

    masm –> [.ASM]
    link –> [.OBJ]

    masm c:\1;
    link 1;

汇编语言(各章知识点) 课程介绍 第1章 预备知识  1.1 汇编语言的由来及其特点   1 机器语言   2 汇编语言   3 汇编程序   4 汇编语言的主要特点   5 汇编语言的使用领域  1.2 数据的表示和类型   1 数值数据的表示   2 非数值数据的表示   3 基本的数据类型  1.3 习题 第2章 CPU资源和存储器  2.1 寄存器组   1 寄存器组   2 通用寄存器的作用   3 专用寄存器的作用  2.2 存储器的管理模式   1 16位微机的内存管理模式   2 32位微机的内存管理模式  2.3 习题 第3章 操作数的寻址方式  3.1 立即寻址方式  3.2 寄存器寻址方式  3.3 直接寻址方式  3.4 寄存器间接寻址方式  3.5 寄存器相对寻址方式  3.6 基址加变址寻址方式  3.7 相对基址加变址寻址方式  3.8 32位地址的寻址方式  3.9 操作数寻址方式的小结  3.10 习题 第4章 标识符和表达式  4.1 标识符  4.2 简单内存变量的定义   1 内存变量定义的一般形式   2 字节变量   3 字变量   4 双字变量   5 六字节变量   6 八字节变量   7 十字节变量  4.3 调整偏移量伪指令   1 偶对齐伪指令   2 对齐伪指令   3 调整偏移量伪指令   4 偏移量计数器的值  4.4 复合内存变量的定义   1 重复说明符   2 结构类型的定义   3 联合类型的定义   4 记录类型的定义   5 数据类型的自定义  4.5 标号  4.6 内存变量和标号的属性   1 段属性操作符   2 偏移量属性操作符   3 类型属性操作符   4 长度属性操作符   5 容量属性操作符   6 强制属性操作符   7 存储单元别名操作符  4.7 表达式   1 进制伪指令   2 数值表达式   3 地址表达式  4.8 符号定义语句   1 等价语句   2 等号语句   3 符号名定义语句  4.9 习题 第5章 微机CPU的指令系统  5.1 汇编语言指令格式   1 指令格式   2 了解指令的几个方面  5.2 指令系统   1 数据传送指令   2 标志位操作指令   3 算术运算指令   4 逻辑运算指令   5 移位操作指令   6 位操作指令   7 比较运算指令   8 循环指令   9 转移指令   10 条件设置字节指令   11 字符串操作指令   12 ASCII-BCD码调整指令   13 处理器指令  5.3 习题 第6章 程序的基本结构  6.1 程序的基本组成   1 段的定义   2 段寄存器的说明语句   3 堆栈段的说明   4 源程序的结构  6.2 程序的基本结构   1 顺序结构   2 分支结构   3 循环结构  6.3 段的基本属性   1 对齐类型   2 组合类型   3 类别   4 段组  6.4 简化的段定义   1 存储模型说明伪指令   2 简化段定义伪指令   3 简化段段名的引用  6.5 源程序的辅助说明伪指令   1 模块名定义伪指令   2 页面定义伪指令   3 标题定义伪指令   4 子标题定义伪指令  6.6 习题 第7章 子程序和库  7.1 子程序的定义  7.2 子程序的调用和返回指令   1 调用指令   2 返回指令  7.3 子程序的参数传递   1 寄存器传递参数   2 存储单元传递参数   3 堆栈传递参数  7.4 寄存器的保护与恢复  7.5 子程序的完全定义   1 子程序完全定义格式   2 子程序的位距   3 子程序的语言类型   4 子程序的可见性   5 子程序的起始和结束操作   6 寄存器的保护和恢复   7 子程序的参数传递   8 子程序的原型说明   9 子程序的调用伪指令   10 局部变量的定义  7.6 子程序库   1 建立库文件命令   2 建立库文件举例   3 库文件的应用   4 库文件的好处  7.7 习题 第8章 输入输出和中断  8.1 输入输出的基本概念   1 I/O端口地址   2 I/O指令  8.2 中断   1 中断的基本概念   2 中断指令   3 中断返回指令   4 中断和子程序  8.3 中断的分类   1 键盘输入的中断功能   2 屏幕显示的中断功能   3 打印输出的中断功能   4 串行通信口的中断功能   5 鼠标的中断功能   6 目录和文件的中断功能   7 内存管理的中断功能   8 读取和设置中断向量  8.4 习题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值