在做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!
JAVA数据类型结构
1>基本数据类型
1.1>数值型:
1.1.1>整数类型(byte,short,int,long)
1.1.2>浮点类型(float,double)
1.2>字符型(char)
1.3>布尔型(boolean)
2>引用数据类型
2.1>类(class)
2.2>接口(interface)
2.3>数组引用
基本类型所占空间:
byte 8bit/1byte
char 16bit/2byte
short 16bit/2byte
int 32bit/4byte
long 64bit/8byte
float 32bit/4byte
double 64bit/8byte
1.自动类型转换
需要同时满足两个条件:
1>两种类型是彼此兼容的
2>转换的目标类型的范围一定要大于转换的源类型
即,宗旨是不能出现数据内存单元的截短,而只能扩大
例:
byte b=3;
int i=b; //编译正常
int i1=3;
byte b1=i1; //编译出错
2.强制类型转换
当两种类型不兼容 或 转换目标类型范围小于转换的源类型.即不满足自动类型转换的条件
格式: 目标类型变量=(目标类型)源类型变量/常量
int i1=3;
byte b1=(int)i1; //编译不会出错
注意:在强制类型转换中目标类型和源类型变量的类型始终没有发生改变.
3.表达式中的数据类型自动提升
Java定义了若干适用于表达式的类型提升规则
第一、byte,char,short→int;
第二、如果有一个操作数是long,计算结果为long型;
第三、如果有一个操作数是float,计算结果为float型;