#include<stdio.h>
int main()
{
unsigned int a = 0xfffffff7;
unsigned char i = (unsigned char)a;
char *b = (char *)&a;
printf("%08x,%08x",i,*b);
}
int main()
{
unsigned int a = 0xfffffff7;
unsigned char i = (unsigned char)a;
char *b = (char *)&a;
printf("%08x,%08x",i,*b);
}
结果输出是000000f7和fffffff7;
16进制的0xfffffff7转化为2进制是 1111,1111,1111,1111,1111,1111,1111,0111
unsigned char i = (unsigned char)a;
int型强制转化成char型,int型是4字节,char型是1字节,于是int型数据的高3字节被截断,于是转化后的char型数据是1111,0111,由于是无符号char型,最高位失去符号位意义,变为数据位,于是直接用0补齐其余的24位,于是结果为0000,0000,0000,0000,0000,0000,1111,0111,转化成2进制即000000f7
char *b = (char *)&a;
此处将指针b指向a所在的内存地址,char型指针只能指向1个字节的数据,所以int型数据a所在的地址的高3个字节被截断,于是char指针现在指向的地址的数据是f7,转化为2进制是1111,0111,最高位为1,此处指针b没有被定义为unsigned,所以表示负数,根据符号位扩张,其余24位用1补充,得到1111,1111,1111,1111,1111,1111,1111,0111,最后将数据转化为16进制即为fffffff7。