Java支持类型的自动精度小的类型可以自动转换为精度大的类型。如下图,
例题:
int a = 10;
float b = 20;
float c = a+b;
c = a-b;
c = a*b;
c = a/b;
因为float的精度比int精度要大,所以上面代码不会出错,int类型会自动转化为float类型。由于运算的两个数值类型都是int类型所以结果也是int类型,但由于Java支持自动提升所以int类型应转换为floa类型;所以 a+b的结果原本该是0.5,但由于a和b都是int类型所以结果是0,但结果要赋给float类型的变量所以自动提升为float类型,结果就是0.00;
看这道题:
short a=1;short m=a+2;
上面代码运行会出错,这是为什么呢?
因为Java中的整数默认为int类型所以2是int类型的,a+2就是一个short类型的变量和一个int类型的值相加,结果当然是int类型的,所以int类型的值赋给short类型的变量会出错。