最近在将一个汇编代码转成C语言,发现一个问题
u8 ad1,ad2,ad3;
u32 data1;
data1= ((u32)ad3<<16)+((u32)ad2<<8)+ad1; // 可以得到正确结果
data1= (ad3<<16)+(ad2<<8)+ad1; // 错误的结果
共8条
1/1 1 跳转至页
3个8位字节转换成一个32位数据,为何不行?
这个要看系统位数和编译器,绝大多数版本比较新的C/C++编译器在32位或者64位系统下,这段代码都不会有问题。根据C/C++现在的标准,在表达式中,char 和 short 类型的值,无论有符号还是无符号,都会自动转换成 int 或者 unsigned int(如果 short 的大小和 int 一样,unsigned short 的表示范围就大于 int,在这种情况下,unsigned short 被转换成 unsigned int)。因为它们被转换成表示范围更大的类型,故而把这种转换称为“升级(promotion)。
data1= (ad3<<16)+(ad2<<8)+ad1这样的语句,ad3,ad2,ad1都会自动转换成unsigned int。如果你的系统是8位或者16位的,这样可能会有问题,因为有的编译器可能会不进行升级,但比较新的编译器应该都能处理的很好。
另外就是union的情况,比较早时,不同的编译器对union的处理也不完全相同,里面也是有坑的。所以有段时间,在写可移植代码的时候,是不推荐用union的。另外通讯代码中使用union要对数据大小端和处理器大小端的情况进行分别定义,而使用位移代码则不需要。
共8条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |