段
什么是段?
8086pc机,再编程时能根据需要定义一组内存单元。定义的这组内存单元被称为段。
分类
代码段、数据段、栈段、附加段
分别对应
CS(代码段寄存器code seggment): 用于存放当前正在运行的程序代码所在段的段基址。相应的偏移地址在r**IP(指令指针寄存器)**中。
DS(数据段寄存器data segment):用于存放当前程序所使用的数据所在段的最低地址。
SS(栈段寄存器 stack segment): 用于存放堆栈段所在最低地址。
ES(附加段数据寄存器 extra segment):用于存放附加数据段(一般指当前串操作指令中串目的地址)所在地址 。
栈
操作系统中,一种数据或线程或操作 后进先出的运行规则。
前面已经知道了ss(栈段寄存器),但是CPU要找到段所在位置并且将数据入栈,还需要一个栈顶(SP :栈顶指针寄存器,用于存放偏移地址)。任意时刻SS:SP指向栈顶的元素。
dos 命令
可以设置debug 模式查看数据处理过程。
// 首先,需要有一个可执行程序 比如a.exe
// 在dos命令行输入 debug a.exe 进入debug模式
// R 命令表示 查看/修改CPU寄存器中的内容
-r //查看
r ax Enter键 0010 //修改 ax的内容为0010
// D 命令表示 查看内存中的内容
-d //查看
d1000:0000 // d段地址:偏移地址 表示查看1000:0000物理地址中的内容
// E 命令表示 改写内存中的内容
-e //改写
e1000:1000 1 2 3 //e段地址:偏移地址 表示修改1000:1000中内容为1 2 3
// U 命令表示 将内存中的机器指令翻译成汇编指令
-u //查看
u //查看当前内容中保存的源码
// T 命令表示 单次执行一条机器指令
-t //执行
t //执行下一条指令
// A 命令表示 以汇编指令的格式在内存中写入一条机器指令
a mov ax,0010
//push 表示更新
push ax //更新ax 先将sp-2 再将ax中的内容送入ss:sp指向的内存单元处,ss:sp随后指向新栈顶。
//pop 表示移动指向
pop ax //将ss:sp指向的内存中的数据送入ax中,然后sp向下移位2位,指向新栈顶下的单元
quit //退出debug模式