首先来看一个问题:
Set<Short> set=new HashSet<>();
for(short i=0;i<100;i++){
set.add(i);
set.remove(i-1);
}
System.out.println(set.size());
结果是:100。
原因:当 short 的 i 进行运算的时候,会先自动转换成 int 类型,当remove时,Set集合中没有 int 类型的数据,所以会删除失败,最后结果就是 100。
在Java运算中,不同类型的数据先转化为同类型,然后进行运算,转换从低级到高级。以下是转换的顺序(
依次从小到大排列):byte ---> shorrt ---> int ---> long ---> float ---> double。
说明:
1、所有的 byte,short,char 型的值将被提升为int型,char类型通过 ASCII 转换;
2、如果有一个操作数是long型,计算结果是long型;
3、如果有一个操作数是float型,计算结果是float型;
4、如果有一个操作数是double型,计算结果是double型;
5、被fianl修饰的变量不会自动改变类型,当2个final修饰相操作时,结果会根据左边变量的类型而转化。
6、两个 int,long,float,double自身来计算的时候没有类型的提升,如果超出范围了就会出现精度的损失 。例如:
int a = 2147483647;
int b = 12;
int d = a + b;
System.out.println(d);
结果:-2147483637。编译不报错,但是结果为负数,表示数字已经超过了int类型的长度,但并不会自动转换类型
7、可以使用大类型去接小类型的计算结果或者定义,反过来则不行。
即:小的表数范围是常量或者变量可以自动的向大的表数范围的类型转换,包括int类型向double类型转换一样。大的表述范围的值不能自动的赋值小的表述范围的变量。
例如:
float f = 1f;
int e = 2;
double db = f + e;
double db = 5.0f;
以上的计算或者定义是不会报错的。