我在X86汇编中有几个关于内存和寄存器的问题:
我有一个字符串"abcdefgh"
,寄存器%eax
包含一个指向字符串的指针。现在我使用movl (%eax), %edx
将字符串的前四个字节抓取到%edx
。它们如何存储在寄存器中?是d
注册中的字符%dl
,还是字符a
?
例如,使用movb %eax, %dl
时,%eax
个字节中的哪个字节确实会移动? %al
中的那个或相反的那个?甚至可以这样做吗?或者我应该使用这样的指针 - movb (%eax), %dh
- 来获取指针指向的第一个字节?
答案 0 :(得分:5)
假设您正在使用不寻常的GAS'语法(source是第一个操作数,destination是第二个操作数)而不是Intel' s:
它们如何存储在寄存器中?是%dl中的字符d 注册,还是字符a?
由于您正在访问字符串,就好像它是32位数字一样,因此适用字节顺序。 x86是little-endian所以你得到最低地址的最低有效字节,所以DL将保持' a' (0x61),整个EDX将为0x64636261。
当使用movb%eax,例如%dl时,%eax' s字节中的哪个字节就可以了 实际上移动? %al或者相反的那个?它甚至可能吗? 这样做?
这会产生语法错误,因为操作数大小不同。你不能将32位移动到8位。
或者我应该使用这样的指针 - movb(%eax),%dh - 来获取 指针指向的第一个字节?
如果你想访问EAX指向的数据而不是EAX本身,那么是的,这应该有效。