实际编程中,经常需要将一种数值类型转换为另一种数值类型
以下是转换的合法规范:
例如:
int n = 123456789;
float f = n; // f is 1.23456792E8
当使用上面两个数值进行二元操作时(例如 n + f, n 是整数, f 是浮点数,) 先要将两个操作数转换为同一种类型,然后再进行计算。
- 如果两个操作数中有一个是 double 类型, 另一个操作数就会转换为 double 类型。
- 否则, 如果其中一个操作数是 float 类型, 另一个操作数将会转换为 float 类型。
- 否则, 如果其中一个操作数是 long 类型, 另一个操作数将会转换为 long 类型。
- 否则, 两个操作数都将被转换为 int 类型
==强制类型转换==
在必要的时候, int 类型的值将会自动地转换为 double 类型。但另一方面,有时也需要将 double 转换成 int。 在 Java 中, 允许进行这种数值之间的类型转换 。
double x = 8.998;
int nx = (int) x;
如果想对浮点数进行舍人运算, 以便得到最接近的整数(在很多情况下, 这种操作更有
用,) 那就需要使用 Math_round 方法:
double x =8.998;
int nx = (int) Math.round(x);
现在, 变量 nx 的值为 9。 当调用 round 的时候, 仍然需要使用强制类型转换( int)。其原因
是 round 方法返回的结果为 long 类型,由于存在信息丢失的可能性,所以只有使用显式的强
制类型转换才能够将 long 类型转换成 int 类型。
警告: 如果试图将一个数值从一种类型强制转换为另一种类型, 而又超出了目标类型的
表示范围, 结果就会截断成一个完全不同的值。 例如,(byte ) 300 的实际值为 44。