栖迟 发表于 2021-12-16 14:50:41

Java数据类型转换:强制类型转换+自动类型转换

  数据类型的转换是在所赋值的数值类型和被变量接收的数据类型不一致时发生的,它需要从一种数据类型转换成另一种数据类型。数据类型的转换可以分为隐式转换(自动类型转换)和显式转换(强制类型转换)两种。

  一、隐式转换(自动类型转换)

  如果以下2个条件都满足,那么将一种类型的数据赋给另外一种类型变量的时,将执行自动类型转换(automatictypeconversion)。

  两种数据类型彼此兼容

  目标类型的取值范围大于源数据类型(低级类型数据转换成高级类型数据)

  当以上2个条件都满足时,拓宽转换(wideningconversion)发生。例如byte类型向short类型转换时,由于short类型的取值范围较大,会自动将byte转换为short类型。

  在运算过程中,由于不同的数据类型会转换成同一种数据类型,所以整型、浮点型以及字符型都可以参与混合运算。自动转换的规则是从低级类型数据转换成高级类型数据。转换规则如下:

  数值型数据的转换:byte→short→int→long→float→double。

  字符型转换为整型:char→int。

  以上数据类型的转换遵循从左到右的转换顺序,最终转换成表达式中表示范围最大的变量的数据类型。

  例1

  顾客到超市购物,购买牙膏2盒,面巾纸4盒。其中牙膏的价格是10.9元,面巾纸的价格是5.8元,求商品总价格。实现代码如下:
public static void main(String[] args) {
    float price1 = 10.9f; // 定义牙膏的价格
    double price2 = 5.8; // 定义面巾纸的价格
    int num1 = 2; // 定义牙膏的数量
    int num2 = 4; // 定义面巾纸的数量
    double res = price1 * num1 + price2 * num2; // 计算总价
    System.out.println("一共付给收银员" + res + "元"); // 输出总价
}
  上述代码中首先定义了一个float类型的变量存储牙膏的价格,然后定义了一个double类型的变量存储面巾纸的价格,再定义两个int类型的变量存储物品的数量,最后进行了乘运算以及和运算之后,将结果储存在一个double类型的变量中进行输出。

  从执行结果看出,float、int和double三种数据类型参与运算,最后输出的结果为double类型的数据。这种转换一般称为“表达式中类型的自动提升”。

  自动类型提升有好处,但它也会引起令人疑惑的编译错误。例如,下面看起来正确的程序却会引起问题:
byte b = 50;
b = b * 2;    // Type mismatch: cannot convert from int to byte
  如上所示,第二行会报“类型不匹配:无法从int转换为byte”错误。
byte b = 50;
b = (byte)(b*2);
  该程序试图将一个完全合法的byte型的值50*2再存储给一个byte型的变量。但是当表达式求值的时候,操作数被自动的提升为int型,计算结果也被提升为int型。这样表达式的结果现在是int型,不强制转换它就不能被赋为byte型。确实如此,在这个特别的情况下,被赋的值将仍然适合目标类型。

  所以应该使用一个显示的强制类型转换,例如:

  这样就能产生正确的值100。

  注意:char类型比较特殊,char自动转换成int、long、float和double,但byte和short不能自动转换为char,而且char也不能自动转换为byte或short。

  二、显式转换(强制类型转换)

  尽管自动类型转换是很有帮助的,但并不能满足所有的编程需要。例如,如果你需要将double型的值赋给一个int型的变量,你将怎么办?

  这种转换不会自动进行,因为double型的变化范围比int型的要小。这种转换有使成为“缩小转换”,因为你肯定要将源数据类型的值变小才能适合目标数据类型。

  所以当两种数据类型不兼容,或目标类型的取值范围小于源类型时,自动转换将无法进行,这时就需要进行强制类型转换。其语法格式如下:
(type)variableName
  其中,type为variableName要转换成的数据类型,而variableName是指要进行类型转换的变量名称,强制转换的实例如下:
int a = 3;
double b = 5.0;
a = (int)b;
  上述代码中首先将double类型变量b的值强制转换成int类型,然后将值赋给a,但是变量b本身的值是没有发生变化的。

  在强制类型转换中,如果是将浮点类型的值转换为整数,直接去掉小数点后边的所有数字;而如果是整数类型强制转换为浮点类型时,将在小数点后面补零。

  例2

  顾客到超市购物,购买牙膏2盒,面巾纸4盒。其中牙膏的价格是10.9元,面巾纸的价格是5.8元,求商品总价格,在计算总价时采用int类型的数据进行存储。实现代码如下:
public static void main(String[] args) {
    float price1 = 10.9f;
    double price2 = 5.8;
    int num1 = 2;
    int num2 = 4;
    int res2 = (int) (price1 * num1 + price2 * num2);
    System.out.println("一共付给收银员" + res2 + "元");
}
  在上述实例中,有double类型、float类型和int类型的数据参与运算,其运算结果默认为double类型,题目要求的结果为int类型,因为int类型的取值范围要小于double类型的取值范围,所以需要进行强制类型转换。


页: [1]
查看完整版本: Java数据类型转换:强制类型转换+自动类型转换