C语言数据类型提升


C代码在遇到数据类型不一致的情况时,编译器会进行自动数据类型提升。

自动转换遵循以下规则:

  1. 如果两种类型字节数不同,则转换成字节数高的类型。
  2. 如果两种类型字节数相同,但一种有符号,一种无符号,则转换成无符号类型
  3. 所有浮点都是以双精度类型进行的,即使只含有单精度运算的表达式,也要先转换成double型,再作运算。

如下图所示:

一般情况下,自动数据类型提升不会引起代码问题,但是需要特别注意的是uint和int类型比较语句时,可能会引起代码逻辑问题。看如下例子:

int32_t  a = -1;
uint32_t b =  1;
if (a > b) {
  printf("a > b\n");
} else {`
  printf("a < b\n");
}

如果我们没有注意到数据类型不一致,而写出了类似上边的代码。由于编译器的自动数据类型提升,代码执行的时候,会将int32_t a转换为uint32_t类型,导致判断语句中"(uint32_t)a"会大于b,从而执行错误的代码逻辑。(本意应该是a < b)

对于这种情况,一种方案是我们将数据类型定义一致;另一种方案是加显示的数据类型转换,如if(a > (int32_t)b)。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM