3.3 数据类型的转换

Java的数据类型在定义时就已经确定了,因此不能随意转换成其他的数据类型,但Java允许用户有限度地做类型转换处理。数据类型的转换方式可分为“自动类型转换”和“强制类型转换”两种。

3.3.1 数据类型的自动转换

在程序中已经定义好了数据类型的变量,若是想用另一种数据类型表示时,Java会在下列的条件皆成立时,自动做数据类型的转换:

(1)转换前的数据类型与转换后的类型兼容。

(2)转换后的数据类型的表示范围比转换前的类型大。

例如,将short类型的变量a转换为int类型,由于short与int皆为整数类型,符合上述条件(1);而int的表示范围比short大,亦符合条件(2)。因此Java会自动将原为short类型的变量a转换为int类型。

值得注意的是,类型的转换只限该行语句,并不会影响原先所定义的变量的类型,而且通过自动类型的转换,可以保证数据的精确度,它不会因为转换而损失数据内容,这种类型的转换方式也称为扩大转换。

前面曾经提到过,若是整数的类型为short或byte,为了避免溢出,Java会将表达式中的short和byte类型自动转换成int类型,即可保证其运算结果的正确性,这也是Java所提供的“扩大转换”功能。

以“扩大转换”来看可能比较容易理解字符与整数是可使用自动类型转换的,整数与浮点数亦是兼容的,但是由于boolean类型只能存放true或false,与整数及字符是不兼容,因此是不可能做类型的转换。接下来看看当两个数中有一个为浮点数时,其运算的结果会有什么样的变化?

【例3.8】数据类型的转换

程序执行结果:

从程序的输出结果可以发现,int类型与float类型进行计算之后,输出的结果会变成float类型,一个整型常量和一个浮点型常量进行计算之后,结果也会变为一个浮点数据。如果是两个int类型的常量进行计算的话,最终结果还是int类型,而其小数部分将会被忽略掉。

也就是说,假设有一个整数和双精度浮点数作运算时,Java会把整数转换成双精度浮点数后再作运算,运算结果也会变成双精度浮点数。关于表达式的数据类型转换,在后面的章节中会有更详细的介绍。

提示

任何类型的数据都向String转型。

一些读者从其他的Java教材之中经常会发现,有一种表示字符串的数据类型String,从其定义上可以发现单词首字母大写了,所以此为一个类,属于引用数据类型,但是此类属于系统的类,而且使用上有一些注意事项,对于此种类型后面会有更详细的介绍,在此处读者需要知道以下两点:

(1)String可以像普通变量那样直接通过赋值的方式进行声明。字符串是使用“"”括起来的。两个字符串之间可以使用“+”进行连接。

(2)任何数据类型碰到String类型的变量或常量之后都向String类型转换。

实例1:定义字符串变量

程序执行结果:

实例2:字符串常量操作的问题

程序执行结果:

从以上的输出结果中可以发现,程序的主要目的是要计算i+j的值,但是由于碰到了字符串常量,所以所有的数据类型都会变为字符串常量,也就是说此时的“+”实际上表示的是字符串连接的含义,对于以上的程序,如果要想得到正确的结果,则必须修改为:

加上括号之后,就表示输出时先计算两个数字相加的结果。

3.3.2 数据类型的强制转换

当两个整数进行运算时,其运算的结果也会是整数。例如,当作整数除法8/3的运算,其结果为整数2,并不是实际的2.33333…,因此在Java中若是想要得到计算的结果是浮点数时,就必须将数据类型做强制性的转换,转换的语法如下:

【格式3-1 数据类型的强制性转换语法】

因为这种强制类型的转换是直接编写在程序代码中的,所以也称为显式转换。下面的程序说明了在Java里整数与浮点数是如何转换的。

【例3.9】数据类型的强制转换

程序执行结果:

在程序中,首先将一个浮点型的变量f的内容给了int型变量x,因为int数据类型的长度小于float类型的长度,所以此处需要进行强制转换。程序的最后使用了两个整型产量进行计算,但是因为将其中的一个整型变量变为了float类型,所以在计算的时候会强制把其他的整型也变为float类型,所以计算的结果是包含小数的。

只要在变量前面加上欲转换的数据类型,运行时就会自动将此行语句里的变量做类型转换的处理,但这并不影响原先所定义的数据类型。

此外,若是将一个超出该变量可表示范围的值赋值给这个变量时,这种转换称为缩小转换。由于在转换的过程中可能会丢失数据的精确度,Java并不会自动做这些类型的转换,此时就必须要做强制性的转换。