数据类型转换
类型转换是将一个值从一种类型更改为另一种类型的过程。
如:将 String型 类型数据“45”转换为一个整型数据,而且可以将任意类型的数据转换为 String 类型。
如果从低精度数据类型向高精度数据类型转换,则永远不会溢出,并且总是成功的;而把高精度数据类型向低精度数据类型转换则必然会有信息丢失,有可能失败。
数据类型转换有两种方式,即隐式转换与显式转换。
1 隐式转换
从低级类型向高级类型的转换,系统将自动执行,不会丟失信息,无须进行任何操作,直接赋值运用。这种类型的转换称为隐式转换,不用刻意,直接自动转化隐式转换也可以称为自动转换。
下列基本数据类型会涉及数据转换顺序
这些类型按精度从“低”到“高”排列的顺序为byte(1字节)<short (2字节)<int(char互换,在数据类型允许范围内可互换)< long (8字节)< float(4字节)<double(8字节)。
Java中的整形数据类型是指数据没有小数部分。Java有4种整型数据类型,分别是byte、short、int和long。这些数据类型的精度大小不同根据字节长度判定,从高到低排列依次为:long、int、short和byte。
long类型精度最高,它的取值范围为-2^63到2^63-1,所以在大数值的计算运算过程中需要使用long类型。int类型的精度是次高的,它的取值范围为-2^31到2^31-1,一般情况下,整数计算需要使用int类型。short类型的精度较低,取值范围为-2^15到2^15-1,一般使用short类型时数据不应太大。byte类型的精度是最低的,取值范围为-2^7到2^7-1。
Java中的浮点型有两种,分别是float和double。与整型数据类型不同,浮点型数据类型的精度是由小数点后的位数来确定的,它们的精度大小,从高到低排列依次为:double和float。浮点数小数点前位数用阶乘
表示,兼整数小数,精度高于整数。
使用int型变量为 float 型变量赋值,此时 int型变量将隐式转换成 float型变量。直接自动转换,无需转换同一类型,再进行赋值给变量。
int x = 50; // 声明int 型变量x
float y = x; // 将x赋值给y
此时执行输出语句, y的结果将是50.0。
隐式类型的转换需要遵循一定的规则,补充位数,不影响数据大小。
隐式转换从低精度向高精度转化来创建不同数值类型的变量。
public class ImplicitConversion {
public static void main(String[] args) {
// 声明byte型变量mybyte,并把byte型变量允许的值赋给 mybyte
byte mybyte = 127;
int myint = 150; // 声明int 型变量myint, 并赋值150
float myfloat = 452.12f; // 声明float型变量 myfloat, 并赋值
char mychar= 10; // 声明 char 型变量mychar,并赋值
double mydouble = 45.46546;// 声明 double型变量,并赋值
/*将运算结果输出 */
System. out. println("byte型与 float 型数据进行运算结果为:"+(mybyte+myfloat));
System. out. println("byte型与int 型数据进行运算结果为: " + mybyte * myint);
System. out. println("byte型与 char型数据进行运算结果为: " + mybyte / mychar);
System. out. println("double型与 char 型数据进行运算结果为: " + (mydouble +mychar));
}
}
运行结果:
byte型与float型数据进行运算结果为: 579.12
byte型与int型数据进行运算结果为: 19050
byte型与char型数据进行运算结果为: 12
double型与char型数据进行运算结果为: 55.46546
如果实例中的float和 int交换了位置,编译环境就会弹出“float值无法转变成int值”的错误。
float x = 50;
int y = x;
/*应用int y=(int)x */
float 值无法转变成int值时,需要用到显示转换。
2 显式转换
当把高精度的变量值赋给低精度的变量时,必须使用显式类型转换运算(又称强制类型转换),当执行显式类型转换时可能会导致精度损失。
语法如下:
(类型名) 要转换的值
显式数据类型转换:
将不同的数据类型进行显式类型转换。
public class ExplicitConversion {
public static void main(String[] args) {
int a = (int) 45.23; // double 类型强制转化成 int类型
long b = (long) 456.6F; // float 类型强制转化成 long 类型
char c = (char) 97.14;// double 型强制转换成 char型
System. out. println("45.23强制转换成 int的结果: " + a);
System. out. println("456.6F强制转换成long 的结果: " + b);
System. out. println("97.14 强制转换成 char 的结果" + c);
运行结果如图2.12所示。
45.23强制转换成int的结果:45
456.6F强制转换成long的结果: 456
97.14强制转换成char的结果a
当执行显式类型转换时可能会导致精度损失。
当把整数赋值给一个byte、short、int、long型变量时,不可以超出这些变量的取值范围,否则必须进行强制类型转换,会丟了信息。例如:
byte b = (byte)129;
什么情况下数据会强制转换
1.同类型大数据类型需要转换为小数据类型。例如,long类型需要转换为int类型,double类型需要转换为float类型。
2. 浮点数类型需要转换为整数类型。例如,float类型需要转换为int类型。
如:double类型数据被强制转换成int类型的数据
public class Test {
public static void main(String[] args) {
double doubleNum = 3.1415926;
int intNum = (int) doubleNum; System.out.println("强制转换前的double值为:" + doubleNum);
System.out.println("强制转换后的int值为:" + intNum);
}
}
将一个double类型的变量doubleNum强制转换为int类型的变量intNum。强制转换的语法是在需要转换的变量前加上括号并在括号内指定目标类型。在强制转换后,原始值被截断为整数,发生精度丢失。