上题目:
#include<iostream>
using namespace std;
int main()
{
unsigned int a = 0xFFFF12F7;
unsigned char i = (unsigned char)a;
char* b = (char*)&a;
printf("%x\n", *b);
printf("%08x, %x\n", i, *b);
b++;
printf("%04x\n", *b);
}
由于这个例子陷阱比较多,故拿出来说一下。
i输出没啥问题,uint赋值给uchar的时候发生截断,只取了一个字节。然后打印出来。
b的情况比价复杂,
char* b = (char*)&a;
这里是将b指到跟a一样的位置,但是是char类型的指针。printf的时候会自动提升长度,char类型的提升到4个字节。如果是float会提升到8个字节。
然后,由于是char类型,而不是unsigned char,这个数据是有符号的,并且是一个负数。负数并且是4个字节,那就是0xFFFFFFF7.打印的时候不管是%08x还是%x或者是%02x,都是输出的这个是数,因为有规则,如果%后面的数字比较小,仍然按照数据本身的长度。
但是如果是正数,例如后面我把b++操作,是一个正数,那么真实长度就只有2,%后面的数字就能起作用了。