三章——汇编知识整理之寄存器(内存访问)
内存中的字
一个字16位,一个内存单元8位,储存一个字需要两个内存单元,并且这两个单元一般是连续的。高8位存放高位字节,低8位存放低位字节。
字单元:存放一个字型数据的内存单位,由两个地址连续的内存单元组成。
DS和[XX]
DS是段寄存器,通常来存放我们要读取的数据的段地址,[XX],表示偏移地址为XX的内存单元,有了段地址还有偏移地址,我们就可以得到内存单元具体的地址,从而进行数据访问。
段寄存器不能像通用寄存器那样操作运算,mov不涉及运算,只是传送指令。
栈
一种具有特殊访问形式的储存空间,也就是LIFO(Last in First Out)。
如图所示:
如何访问栈
我们知道,计算机只认识1和0,不知道0和1组成的一些列数字哪一些是指令,哪一些是数据。为了解决这个问题,我们规定,CS:IP表示的地址指向指令,DS:[XX] 指向的地址表示数据。那么,我们可以推测,应该存在指向栈的段寄存器还有储存其偏移地址的寄存器。
SS和SP
段寄存器SS:储存着栈的段地址。 SP:储存着栈的偏移地址。
SS:SP 指向栈的顶部元素,简称栈顶,也就是操作空间。
入栈:PUSH 出栈:POP
有了地址,就可以对栈里面的元素进行操作了。
入栈和出栈的操作单位都是一个字,也就是说:入栈一次是入栈一个字,出栈一次也是出一个字。
在CPU中,用16位的寄存器来储存一个字,刚好一个字是16位。
假设栈里面是空的,SS:SP 指向栈顶空间。
push AX(寄存器) //把AX的送入栈中
pop BX(寄存器) //把栈里面的元送到BX中
PUSH的过程。
栈的初始化状态:
SS:1000 H //H表示16进制
SP:000E H
AX:2266 H
例如:push ax
1.SP = SP -2 //减2的原因:一个内存单元是8位,两个内存单元就是16位,而出栈是以一个字的单位来进行的。
2.将ax里面的数据送到栈里面。
每进行一次push运算,sp自己会减少二。
POP的过程
和PUSH反过来。
例如:pop ax
1.先把栈中的数据送到ax里面,栈里面的元素是没有变化的,送到ax里面的数据是复制过去了,不是剪切过去的。
2.然后在SP = SP + 2。
初始化,自定义栈
将10000H~1000F当作栈的空间,栈的空间是空的。
mov ax,2000
mov ss,ax //把寄存器ax的值送到ss里面,不能直接把数据传递到ss里面。
mov sp,010 //设置SP的初值。
Debug的T命令在执行修改寄存器SS的指令时,下一条指令也紧接着被执行。