第三章 寄存器(内存访问)
3.1 内存中字的存储:CPU中用16位寄存器存储一个字,高八位放高位字节,第八位放低位字节,
我们的存储有两种方式,一种是大端法,一种是小端法
3.2 DS和[address]
CPU要读写内存单元的时候,必须先给出这个内存单元的地址,内存单元的地址由段地址和偏移地址组成
DS寄存器是用来存放数据的段地址。“[...]”表示的是一个内存单元,其中的数字代表 内存单元的偏移地址,同时
mov 指令可以将数据送入内存单元,但是不能直接将一个内存单元的数据直接送入另一个内存单元
3.3 字的传送
在mov指令中给出16位的寄存器,可以一次性传送16位数据
3.4 mov add sub 指令
mov的用法: mov 段寄存器 ,寄存器。 mov 内存单元 ,寄存器。 mov 段寄存器,内存单元。
同样的add就是实现数据的加,sub就是实现数据的减,用法同mov
3.5 数据段
编程时,为了需要,将一组内存单元定义为一个段。再具体操作时,用ds存放数据段的段地址,在用相关的指令访问数据的具体单元
字在内存单元的存储要用两个地址连续的内存单元
3.6 栈
栈就是先进后出,LIFO,很简单
3.7 CPU提供的栈机制
两种操作:PUSH进栈,POP出栈 push ax 就是讲ax中的数据送入栈中,同理pop ax 就是把栈中数据送入ax
入栈和出栈操作都是以字为单位进行的,其中有两个寄存器叫 CS段寄存器和SP寄存器,栈顶的段地址存放在SS中
偏移地址存放在SP中。任意时刻,SS:SP指向栈顶元素
当PUSH ax执行的时候SP=SP-2;同理POP ax就要加2