Dreaming... 发表于 2012-5-7 19:01:49

汇编的地址偏移问题


我在看到这段汇编代码的时候相当不明白
int *point;
int a;
_asm
{
      mov ebx,point
      mov ebx,
      mov a,ebx
}
不管他们的值是多少,现在主要是这个问题。

在汇编代码中,首先将point的地址传入ebx,然后第二句我就不明白了,字面
意思可以明白,取ebx所指向的值再送到ebx,可问题是这儿存在一个偏移问题
,意思是取这个地址的值送到ebx,前面是直接送的point的地址
而后面我们这里还加上了ds*16,他们的值我们的初衷有很大的偏差。

大家看看,这到底怎么回事?


Dreaming... 发表于 2012-5-7 20:27:46

自己看明白了,原因是平台不同,也就是编译环境不同;
加上偏移的情况,是在纯汇编环境中,而在VC内嵌汇编中,不需要经过加上段寄存器*16
因为内嵌后的代码,还要被编译器重新解释,编译!

洗脚水煮饺子 发表于 2012-5-8 21:47:20

原来如此啊谢谢楼上的哈哈

Dreaming... 发表于 2012-5-13 02:04:56

洗脚水煮饺子 发表于 2012-5-8 21:47 static/image/common/back.gif
原来如此啊谢谢楼上的哈哈

不乘上诸如DS*16 的形式,是因为在Win 32位平台下的情况;而加上DS*16 的情况是在16为平台下;

Win16位平台使用的是   段地址*16+段内偏移地址,Win32位平台使用的是   平坦的内存地址寻址模式寻址(即:直接跟上地址);

后来的看到了话,注意了,以前理解错了;

brighthsj 发表于 2012-5-14 01:28:27

楼上正解,不过有点不明白,IP 是根据什么自动加值的!
页: [1]
查看完整版本: 汇编的地址偏移问题