【发布时间】:2013-01-05 07:11:13
【问题描述】:
我最近一直在(重新学习)较低级别的 CS 材料,并且一直在探索缓冲区溢出。我创建了一个基本的 C 程序,它有一个 8 字节数组 char buffer[8];。然后我使用 GDB 探索和反汇编程序并逐步执行它。我在 64 位版本的 Ubuntu 上,我注意到我的 8 字节 char 数组实际上在内存中以 16 字节表示 - 高位都只是 0。
例如而不是 0xDEADBEEF 0x12345678 我可能期望代表 8 字节数组,它实际上类似于 0x00000000 0xDEADBEEF 0x00000000 0x12345678。
我做了一些谷歌搜索,并能够让 GCC 将我的程序编译为 32 位程序(使用 -m32 标志) - 这导致预期的 8 个字节正常。
我只是在寻找一个明确的解释,说明为什么 8 字节字符数组在 64 位系统上以 16 字节表示。是不是因为最小字长/可寻址单元是 16 字节(64 位),而 GDB 只是基于 8 字节字长打印?
希望这很清楚,但如果需要澄清,请告诉我。
【问题讨论】:
-
这个
char buffer[8];在哪里?它在struct内吗?它在堆栈上吗? -
尝试使用#pragma pack解决
-
仅供参考,16 字节是 128 位。
-
如果您能向我们展示您使用的确切代码以及编译器版本和选项会更清楚。我们所能做的就是推测。
-
@UrielFrankel #pragma pack 没有加入其中。 T 的数组的大小是 T 的大小的 n 倍,总是 (C99 6.5.3.4:6),char 的大小是一,总是 (C99 6.5.3.4:3)。
标签: c 64-bit x86-64 32bit-64bit sizeof