一,自动转换
一个 int 类型变量和一个 byte 类型变量进行加法运算, 结果会是什么数据类型?
> int i = 1; byte b = 2;
运算结果,变量的类型将是 int 类型,这就是出现了数据类型的自动类型转换现象。 自动转换:将 取值范围小的类型 自动提升为 取值范围大的类型 。
> public static void main(String[] args)
> { int i = 1; byte b = 2; //
> byte x = b + i; // 报错
> //int类型和byte类型运算,结果是int类型 int j = b + i;
> System.out.println(j); }
转换原理图解
byte 类型内存占有1个字节,在和 int 类型运算时会提升为 int 类型 ,自动补充3个字节,因此计算后的结果还是 int 类 型。
同样道理,当一个 int 类型变量和一个 double 变量运算时, int 类型将会自动提升为 double 类型进行运算。
> public static void main(String[] args) {
> int i = 1;
> double d = 2.5; //int类型和double类型运算,结果是double类型
> //int类型会提升为double类型
> double e = d+i;
> System.out.println(e); }
转换规则 范围小的类型向范围大的类型提升, byte、short、char 运算时直接提升为 int 。
> byte、short、char‐‐>int‐‐>long‐‐>float‐‐>double
二,强制转换
将 1.5 赋值到 int 类型变量会发生什么?产生编译失败,肯定无法赋值。
>int i = 1.5; // 错误
转换原理图解
强烈注意
浮点转成整数,直接取消小数点,可能造成数据损失精度。 int 强制转成 short 砍掉2个字节,可能造成数据丢失。
>// 定义s为short范围内最大值 short s = 32767; // 运算后,强制转换,砍掉2个字节后会出现不确定的结果 s = (short)(s + 10);