目录
一、基本概念
1、自动类型转换:当java程序在进行赋值或者运算时,精度小的类型,自动转换为精度大的数据类型,这个就是自动类型转换。
数据类型按精度容量大小排序为:
注:一有多种类型的数据混合运算时,系统首先自动将所有数据转换成容量最大的那种数据类型,然后再进行计算。
2、当我们把精度容量大的数据类型赋值给精度容量小的数据类型时就会报错,反之就会进行自动类型转换
3、byte、short和char之间不会相互自动转换
4、byte,short,char他们三者可以计算,在计算时首先转换为int类型
5、boolean不参与转换
6、自动提升原则表达式结果的类型,自动提升为操作数中最大的类型
7、复合赋值运算符会自动进行类型转换,如:
byte a = 2;
a += 3; (这一句是正确的,等价于 a = (byte) (a + 3) )
a = a + 3; (但这一句是错误的)
二、代码解释
public class AutoConvertDetail {
//编写一个main方法
public static void main(String[] args) {
//细节1: 有多种类型的数据混合运算时,
//系统首先自动将所有数据转换成容量最大的那种数据类型,然后再进行计算
int n1 = 10; //ok
//float d1 = n1 + 1.1;//错误 n1 + 1.1 => 结果类型是 double
//double d1 = n1 + 1.1;//对 n1 + 1.1 => 结果类型是 double
float d1 = n1 + 1.1F;//对 n1 + 1.1 => 结果类型是 float
//细节2: 当我们把精度(容量)大 的数据类型赋值给精度(容量)小 的数据类型时,
//就会报错,反之就会进行自动类型转换。
//
//int n2 = 1.1;//错误 double -> int
//细节3: (byte, short) 和 char之间不会相互自动转换
//当把具体数赋给 byte 时,(1)先判断该数是否在byte范围内,如果是就可以
byte b1 = 10; //对 , -128-127
// int n2 = 1; //n2 是int
// byte b2 = n2; //错误,原因: 如果是变量赋值,判断类型
//
// char c1 = b1; //错误, 原因 byte 不能自动转成 char
//
//
//细节4: byte,short,char 他们三者可以计算,在计算时首先转换为int类型
byte b2 = 1;
byte b3 = 2;
short s1 = 1;
//short s2 = b2 + s1;//错, b2 + s1 => int
int s2 = b2 + s1;//对, b2 + s1 => int
//byte b4 = b2 + b3; //错误: b2 + b3 => int
//
//boolean 不参与转换
boolean pass = true;
//int num100 = pass;// boolean 不参与类型的自动转换
//自动提升原则: 表达式结果的类型自动提升为 操作数中最大的类型
//看一道题
byte b4 = 1;
short s3 = 100;
int num200 = 1;
float num300 = 1.1F;
double num500 = b4 + s3 + num200 + num300; //float -> double
}
}
我是花花,祝自己也祝您变强了~