看这样一道题:
#include <stdio.h>
int main(void)
{
int w, h;
int i = 0xa1b2c3d4;
char *p = (char *)&i;
for (int j = 0; j < 4; j++)
{
char c = p[j];
printf("%02x\n", c);
}
return 0;
}
输出结果是什么?
ffffffd4
ffffffc3
ffffffb2
ffffffa1
char只有一个字节,打印出来却是4个字节,与想象的不一样啊,
如果改动一下就对了,
#include <stdio.h>
int main(void)
{
int w, h;
int i = 0xa1b2c3d4;
unsigned char *p = (unsigned char *)&i;
for (int j = 0; j < 4; j++)
{
unsigned char c = p[j];
printf("%02x\n", c);
}
return 0;
}
d4 c3 b2 a1
这是因为:
1)在x86平台是littelEndian字节序,所以会倒序,先遍历到低位;
2)char 类型等于是有符号,在打印时候,会将高位按照符号位补全1,所以会打印多余的FF,这里与printf的实现有关,

本文通过两个示例程序展示了在x86平台上,不同类型的指针遍历整型变量时的字节序差异。解释了littelEndian字节序下数据的存储顺序,并分析了使用char类型指针时的符号位补全现象。
6183

被折叠的 条评论
为什么被折叠?



