求助高手,一个令我郁闷了一天的问题
时间:10-02
整理:3721RD
点击:
main()
{
unsigned char a[4]= {0x12, 0x34, 0x56, 0x78};
unsigned long i, j;
i = (a[0] << 24) + (a[1] << 16) + (a[2] << 8) + a[3];
j = a[0] * 0x1000000 + a[1] * 0x10000 + a[2] * 0x100 + a[3];
return 0;
}
我以为 i = 0x12345678, 实际上 i = 0x00005678, 查了半天错,最后改成了第二个式子才得一通过
实在是想不明白,为什么i的值只有低16位
{
unsigned char a[4]= {0x12, 0x34, 0x56, 0x78};
unsigned long i, j;
i = (a[0] << 24) + (a[1] << 16) + (a[2] << 8) + a[3];
j = a[0] * 0x1000000 + a[1] * 0x10000 + a[2] * 0x100 + a[3];
return 0;
}
我以为 i = 0x12345678, 实际上 i = 0x00005678, 查了半天错,最后改成了第二个式子才得一通过
实在是想不明白,为什么i的值只有低16位
应该是数据类型的范围限制了。
你把数组a定义成long型的就知道哪错了
我想知道的是,为什么用char型不行
溢出
字符型是8位的,它为什么左移8位的时候没有溢出,而左移16位后就溢出了呢
在移位运算时,byte、short和char类型移位后的结果会变成int类型,也就是16位,移位24位和16位已经溢出了,只保留低16位,所以都是0x00000000,移位8位就是0x5600,所以最后结果是0x00005678。而第二条语句中因为已经有long型变量参与运算,结果会自动变为long型不会溢出,所以结果正确
谢谢,我已经想明白了,这是C语言的强制数据类型转换,常数默认的是类型是int型