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