自动类型转换
前提:这里讨论只是7种基本数据类型变量间的运算。不包含boolean类型的。
- 自动类型转换:容量小的类型自动转换为容量大的数据类型。数据类型按容量大小排序为:
- 有多种类型的数据混合运算时,系统首先自动将所有数据 转换成容量最大的那种数据类型,然后再进行计算。
- byte,short,char之间不会相互转换,他们三者在计算时首先转换为int类型。
- boolean类型不能与其它数据类型运算。
- 当把任何基本数据类型的值和字符串(String)进行连接运算时(+),基本数据类型的值将自动转化为字符串(String)类型。
结论:当容量小的数据类型的变量与容量大的数据类型的变量做运算时,结果自动提升为容量大的数据类型。
说明:此时的容量大小指的是,表示数的范围的大和小。比如:float容量大于long的容量
强制类型转换
- 将容量大的数据类型转换为容量小的数据类型。使用时要加上强制转换符:(),但可能造成精度降低或者溢出,格外要注意。
- 通常,字符串不能直接转换为基本类型,但通过基本类型对应的包装类则可以实现把字符串转换为基本类型。(String可以和8种基本数据类型变量做运算,且运算只能是连接运算:+,且运算结果仍然是String类型)
- 如:String a="43"; int i=Integer.parseInt(a);
- boolean类型不可以转换为其它的数据类型。
//精度损失 int a = 128; byte b = (byte) a; System.out.println(b);//-128
// 末尾不加L,不报错是因为自动把右边的值看成int, // int的范围是10位数,int赋给一个long,属于自动 // 类型提升 long l = 12344; // 加L,是因为超出int最大取值范围 long l1 = 2222222222L; 整数常量,默认类型为int型 浮点数常量,默认类型为double型 byte n = 12; byte n2 = n + 1; //编译不通过 float f = n + 12.3; //编译不通过