我们可以将一段内存定义为一个段,用一个段地址指示段,用偏移地址访问段内的内存单元。我们想怎么定义就怎么定义。
1.我们可以定义一个段来存放数据,将他定义为“数据段”
2.我们可以定义一个段来存放代码,将他定义为“代码段”
3.我们可以定义一个段来当作栈,将他定义为段栈
对于数据段,我们通过普通寄存器AX,BX,CX,DX来给DS段存储器赋值,将我们定义的数据段的段地址存放在DS中,再通过偏移地址去访问数据段中的内存单元,CPU就将我们定义的数据段中的内容当作数据来访问。
对于代码段,将他的段地址存放在CS代码段寄存器中,将第一条指令的偏移地址存放在IP指令指针寄存器中,这样cpu就将执行我们的代码段中的指令。
对于栈段,将他的段地址存放在SS中,将栈顶单元的偏移地址放在SP中,这样CPU在需要进行入栈出栈操作的时候,就将我们定义的段栈当作栈空间来用。
由此,相信大家一下就彻悟了,我们之前在学习汇编语言的过程中,一段内存中存放的数据和指令其实都是二进制的形式没有区别,在于你把这些数据当作指令来用,还是当作数据来使用
一段内存,可以既是代码的存储空间,又是数据的存储空间,还可以是栈空间,也可以什么都不是,就一段内存空间,之所以区分指令和数据,区分栈段,数据段,代码段,完全是因为CS,IP,SS,SP,DS寄存器的作用。