数据类型的转换是在所赋值的数值和被变量接收的数据类型不一致时发生的,它需要从一种数据类型转换成另一种数据类型。数据类型的转换可以分为隐式转换(自动类型转换)和显示转换(强制类型转换)两种。
1. 隐式转换(自动类型转换)
如要以下 2 个条件满足,那么将一种类型的数据赋给另外一种类型变量时,将执行自动类型转换(automatic type conversion):
两种数据类型彼此兼容;
目标类型的取值范围大于源数据类型(低级类型数据转换成高级类型数据)。
当以上 2 个条件都满足时,拓宽转换(widening conversion)发生。例如,byte 类型向 short 类型转换时,由于 short 类型转换时,由于 short 类型取值范围较大,会自动将 byte 转换为 short 类型。
在运算过程中,由于不同的数据类型会转换成同一种数据类型,所以整型、浮点型以及字符型都可以参与混合运算。自动转换的规则是从低级类型数据转换成高级类型数据。转换规则如下:
数值型数据的转换:byte → short → int → long → float → double ;
字符型转换为整型:char → int 。
*注:char 类型比较特殊,char 自动转换成 int、long、float、double ,但 byte 和 short 不能自动转换为 char ,而且 char 也不能自动转换为 byte 或 short 。
比如说,float 、int 和 double 三种数据类型都参与了一个运算,最后输出结果就是 double 类型的,这种转换一般称为“表达式中类型的自动提升”。
自动类型提升有好处,但它也会引起令人疑惑的编译错误。例如,下面这段看起来正确的程序却会引起问题:
1:byte b = 50;
2:b = b * 2; //Type mismatch: cannont convert from int to byte
为什么第二行会报“类型不匹配:无法从 int 转换为 byte”的错误呢?
该程序试图将一个完全合法的 byte 类型的值 50*2 再存储给一个 byte 类型的变量,但是当表达式求值的时候,操作数被自动的提升为 int 型,计算结果也被提升为 int 型。如此以来,这样表达式的结果现在就是 int 型了,不强制转换它自然就不能被赋为 byte 型。所以,在这个特别的情况下,应该使用一个显示的强制类型转换,如下:
1:byte b = 50;
2:b = (byte)(b * 2);
这样就能产生正确的值 100 了。
2. 显示转换(强制类型转换)
当两种数据类型不兼容,或目标类型的取值范围小于源类型时,自动转换将无法时行,这时就需要进行强制类型转换。其语法格式如下:
(type)variableName
其中,type 为 variableName 要转换成的数据类型,而 variableName 是指要进行类型转换的变量名称。
在强制类型转换中,如果是将浮点型的值转换为整数,直接去掉小数点后边的所有数字;而如果是整数类型强制转换为浮点类型时,将在小数点后面补零。