运维开发网

我的64位机器每个存储器位置只能存储4个字节

运维开发网 https://www.qedev.com 2020-04-20 17:34 出处:网络 作者:运维开发网整理
我的电脑是64位mac. 在内存中的其中一个位置存储了多少字节的信息? 当我在gdb中尝试一些东西时 x /2x first 0x7ffff661c020: 0xf661b020 0x00007fff 我的代码是 #define PUT(p, val) (*((size_t *)(p)) = (val)) PUT(first, (size_t)some pointers); 我用gcc
我的电脑是64位mac.

在内存中的其中一个位置存储了多少字节的信息?

当我在gdb中尝试一些东西时

x /2x first
0x7ffff661c020: 0xf661b020      0x00007fff

我的代码是

#define PUT(p, val) (*((size_t *)(p)) = (val))
PUT(first, (size_t)some pointers);

我用gcc -g编译

似乎只有4个字节存储在0x7ffff661c020中. 0x0000ffff1存储在0x7ffff661c024中.为什么它不能在0x7ffff661c020中存储0x00007ffff661b020.

谢谢

每个存储单元只能存储8位,因为存储器是字节可寻址的. 64位机器在每个内存位置都不会给你64位,它只是意味着它一次可以自然地处理64位.

例如,寄存器是64位宽(除非您有意操作子寄存器,如ax或eax而不是64位rax),并且您可以使用单个指令从存储器中加载那么多位.

你可以看到,你的两个地址之间的差异为4,这是字节可寻址的:

0x7ffff661c020: 0xf661b020
0x7ffff661c024: 0x00007fff
              \____________/ four-byte
                           \ difference

并且,如果您使用基于字节的输出,您会更“自然地”看到它,例如:

(gdb) x/8xb first
0x7ffff661c020: 0x20 0xb0 0x61 0xf6 0xff 0x7f 0x00 0x00

因此,0x7ffff661c020处的64位值实际上是0x00007ffff661b020,您只需要调整gdb命令将其作为完整的64位值取出,例如:

x/1xg first

其中1xg表示一个值,十六进制格式,巨字(八个字节).有关x命令的详细信息可以在here找到,您问题的重要位是单位大小的描述(我的粗体):

> b =字节.> h =半字(两个字节).> w =单词(四个字节).这是初始默认值.> g =巨字(八字节).

0

精彩评论

暂无评论...
验证码 换一张
取 消