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