3.寄存器(内存访问)

  1. CPU中,用16位来存储一个字。高8位存放高位字节,低8位存放低位字节。
  2. 内存存储中,内存单元是字节单元(1单元=1字节),则一个字要用两个地址连续的内存单元存放。
  3. 内存存储中,高位字节,和低位字节是相对的,指令指向的是低位字节。
  4. 字单元,即存放一个字型数据(16位=2字节)的内存单元,由两个地址连续的内存单元组成。
  5. 8086CPU中有一个DS寄存器,通常用来存放要访问数据的段地址
  6. MOV指令的几种种功能:
    • 将数据直接送入寄存器 mov ax,1000H
    • 将一个寄存器中的内容送入另一个寄存器 mov ax,bx;mov ds,ax
    • 将一个内存单元中的内容送入寄存器 mov ax,[...]
    • 将寄存器中的内容送入内存单元 mov [...],ax
    • ...
  7. “[...]”表示一个内存单元,“[...]”中的内容则表示内存单元的偏移地址。
  8. 8086CPU中,不能给DS寄存器直接赋值,需要通过通用寄存器间接赋值,如“段地址-->通用寄存器-->DS寄存器”。
  9. add指令表示相加,sub指令表示相减。
  10. [address]便是一个偏移地址为address的内存单元。
  11. mov、add、sub是具有两个操作对象的指令。jmp是具有一个操作对象的指令。
  12. 是一种具有特殊的访问方式的存储空间,它的特殊性就在于,先进后出的特性。
  13. 8086CPU提供了入栈和出栈指令,最基本的两个是PUSH(入栈)POP(出栈)。
  14. 8086CPU的入栈和出栈操作都是以字(2字节)为单位进行的。
  15. 8086CPU中,有两个寄存器,段寄存器SS和寄存器SP,栈顶的段地址存放在SS中,偏移地址存放在SP中。
  16. 任意时刻,SS:SP指向栈顶元素
  17. PUSH入栈时,SP=SP-2(1字),栈顶从高地址向低地址方向增长,出栈时则SP=SP+2.
  18. 栈为空时,栈中没有元素,也就不存在栈顶元素,所以SS:SP只能指向最底部单元下面的单元
  19. 8086CPU不能保证我们对栈的操作不会超界,它只知道栈顶在何处(有SS:SP指示),并不知道这个栈有多大。
  20. push和pop指令可以有如下形式:
    • push  寄存器
    • pop   寄存器
    • push  段寄存器
    • pop   段寄存器
    • push  内存单元
    • pop   内存单元
  21. 请灵活,仔细运用CS:IP(指令),DS:[...](数据),SS:SP(栈)
    • 对于数据段,将它的段地址放在DS中,用mov,add,sub等访问内存单元的指令时,CPU就将我们第一的数据段内容当成数据来访问。
    • 对于代码段,将它的段地址放在CS中,将段中的第一条执行的指令的偏移地址放在IP中,这样CPU就会执行代码段中的指令
    • 对于栈段,将它的段地址放在SS中,将栈顶单元的偏移地址放在SP中,这样CPU在需要进行栈操作时,比如push,pop指令时,就将栈段当成栈空间来用了。
原文地址:https://www.cnblogs.com/zxj159/p/2811380.html