在做stm32编程优化float浮点型运算时考虑到了自动类型提升。。当一个表达式中有浮点型数据时整个表达式会提升为浮点型进行运算,大大增加了运算时间。。
以下部分为复制的相关内容。。。。
面试过java程序员的或多或少对这个题目有点面熟:
short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
答案是:前者错,后者对。why? 且看下面分解:
java类型计算中,除了强制类型转换,还有各不很面熟的自动类型提升
java在表达式中,对中间值的精确要求有时可能会超过任何一个操作数的范围。例如,考虑下面的表达式: byte a = 40; byte b = 50; byte c = 100; int d = a * b / c; 中间项结果a*b 很容易超过它的任何一个byte 型操作数的范围。为处理这种问题,当分析表达式时,Java自动提升各个byte 型或short型的操作数到int 型。这个过程是java自动进行的,所以可要留意了。
现在我们来分析short s1 = 1; s1 = s1 + 1;为什么错
根据自动类型提升,我们知道,s1 (short型)+ 1(int型),结果为(int),将int赋值给short,会损失精度,当然不可以了。
下面记住自动类型提升的一些规则
One. 所有的byte型和short型的值被提升到int型.
Two. 如果一个操作数是long型,整个表达式将被提升到long型
Three. 如果一个操作数是float型,整个表达式将被提升到float型
Four. 如果有一个操作数是double型,计算结果就是double型
Please learn it by heart,it is not bad!
基本类型所占空间:
1.自动类型转换
2.强制类型转换
3.表达式中的数据类型自动提升
Java定义了若干适用于表达式的类型提升规则
第一、byte,char,short→int;
第二、如果有一个操作数是long,计算结果为long型;
第三、如果有一个操作数是float,计算结果为float型;
第四、如果有一个操作数是double,计算结果为double型.