寄存器(内存访问)
内存中的字的存储
略
DS和address
8086CPU中的DS寄存器,通常用来存放要访问数据的段地址
读取10000H单元的内容
mov bx,1000H
mov ds,bx
mov al,[0]
上面3条指令将10000H(1000:0)中的数据读到al中
mov指令的使用
1、将数据直接送入寄存器
2、将一个寄存器中的内容送入另一个寄存器
3、将内存单元数据送入寄存器,mov 寄存器名称,内存单元地址
字的传送
段寄存器DS不支持mov指令的直接赋值,支持寄存器到寄存器直接赋值
所以地址范围超出16位,需要使用到DS寄存器进行寻址
数据大端模式:高地址存储低字节,高地址存储低字节
数据小端模式:低地址存储低字节,高地址存储高字节
mov、add、sub指令
add、sub和mov的操作方式是一致的
数据段
段:可以将一组长度为2^N,地址连续,起始地址为N的倍数的内存单元当作专门存储数据的内存空间
栈
栈:先入后出,LIFO机制
CPU提供的栈机制
push:入栈
pop:出栈
内存空间 = 10000~1000F,此时栈为空
mov ax,0123H
push ax
地址1000F = 01H,地址1000E = 23H
栈的地址是向下增长方向
在执行push、pop指令时,cpu如何知道10000~1000F空间为栈
push ax等入栈指令执行时,要将数据放在栈顶,如何知道哪个位置是栈顶
CPU通过CS、IP中存放的当前指令的段地址和偏移地址来寻址指令
8086CPU中,通过段寄存器SS和寄存器SP来寻址栈顶的位置
将10000~1000F作为栈空间,栈是2字节对齐的
若只有一个元素时,SS = 1000,SP = 1000E
唯一一个元素出栈时候,SP = SP + 2 = 10010
所以栈为空时,SP = 栈最空间最高地址单元地址值 + 1
栈顶超界的问题
如何保证出栈、入栈指令不会越界
push、pop指令
push 寄存器 ;将有何寄存器中的数据入栈
pop 寄存器 ;出栈,用一个寄存器接收出栈的数据
栈的操作是2字节对齐的
mov ax,0123H
push ax
1000F = 01,1000E = 23
栈中字数据还是保持着小端模式
push:先改变SP,再向SS:SP传送数据
pop:先读取数据,再移动指针
内存中的数据,被当作指令、数据、栈取决于CS、IP、SS、SP、DS寄存器