王爽老师汇编语言中2.12代码段中一段话的理解。?
“我们可以将长度为N(N≤64KB)的一组代码,存在一组地址连续、起始地址为16的倍数的内存单元中,我们可以认为,这段内存是用来存放代码的,从而定义了一个代码段”书中是这么写的,我想了解大家对于这段话都是怎么理解的?谢谢
还有个问题,就是:CPU将读取的指令送入指令缓冲器时,IP=IP+所读指令的长度; 那么,CPU是如何知道所读指令的长度的?
先谢谢大家的解答! 自己先顶一下:lol: 问题1:段寄存器*16+偏移地址=内存地址。
段寄存器的内容可以是0000-ffffh
这个0-ffff算一下,一共是64kb
问题2,我也不懂,觉得学到后面应该就懂了,所以一直也没问 CPU的组成大概你已经忘记了,有一个组成部分叫控制单元,专门处理指令的,不想多打字了,上图:
王爽的书中没解释。 vvqboy 发表于 2014-2-19 11:18 static/image/common/back.gif
问题1:段寄存器*16+偏移地址=内存地址。
段寄存器的内容可以是0000-ffffh
这个0-ffff算一下,一共是64kb ...
那是不是这一段,就是IP里的1H? oggplay 发表于 2014-2-19 11:25 static/image/common/back.gif
CPU的组成大概你已经忘记了,有一个组成部分叫控制单元,专门处理指令的,不想多打字了,上图:
书中居然没怎么写CPU的组成……谢谢你了,有完整的吗? Ravox_wn 发表于 2014-2-19 12:23 static/image/common/back.gif
书中居然没怎么写CPU的组成……谢谢你了,有完整的吗?
书中的都是AT&T语法,intel与AT&T汇编 只学一种,否则容易乱 看一看!!! cpu如何得知指令长度,本书的理解是,在指令寄存器中,清点所取指令字节数。 那啥,CPU的一条指令是有几个部分组成,有操作码,操作数,等等,这样既可以逐个匹配,比如
mov ax,bx
mov 是操作码,ax和bx是操作数。
网上有开源的反汇编引擎,你可以参照一下。
页:
[1]