看这样一道题:
#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的实现有关,