Debug种的几个命令:
R:查看、改变CPU寄存器的内容
D:查看内存中的内容
E:改写内存中的内容
U:将内存中的机器指令翻译成汇编指令
T:执行一条机器指令
G:一次执行完循环中的语句,而不是单步执行。也可以执行到指定目的处,例如g 0016
A:以汇编指令的格式在内存中写入一条机器指令
Q:退出debug模式
注意:段寄存器的几个特点
我们可以将一段内存定义为一个段,用一个段地址指示段,用偏移地址访问段内的单元,这都是我们自己安排的。
可以用一个段存放数据,将它定义为数据段。
可以用一个段存放代码,将它定义为代码段。
可以用一个段当作栈,将它定义为栈段。
如果要用CPU去访问这些段,对于数据段,将它的段地址放在DS中;对于代码段,将它的段地址放在CS中,并将段中第一条指令的偏移地址放在IP中;对于栈段,将它的段地址放在SS中,将栈顶单元的偏移地址放在SP中。
不管我们怎么安排,CPU将内存中的某段内容当作代码,是因为CS:IP指向了那里;CPU将某段内存当作栈,是因为SS:SP指向了那里。
***程序将要执行的指令代码在CS+IP的地方了;而代码所用到的数据在DS+[X](x为偏移地址),型如mov ax,[1];而堆栈用到的数据放在了ES+SS中,在push和pop时要用到。就是说想要代码去执行某个代码,就把这个代码放到CS+IP的地方;而如果要用到某个数据,那就把这个数据放在DS+[X]的地方;而如果要用到堆栈中的数据,就把ES+SS的值改为数据在堆栈中个的地址。