基本数据类型之间的运算规则:自动转换 强制转换

1.自动类型提升
这里只是讨论七种数据的运算(不包含布尔型,因为布尔型只有两种情况:false和true)

当容量小的数据类型变量与容量大的数据类型变量做运算时,结果自动提升为容量大的数据类型
即 容量小的数据类型变量+容量大的数据类型变量=容量大的数据类型变量
byte→short→int→long→float→double

说明:此时的容量大小指的是,表示数的范围的大和小。
比如:float容量要大于long的容量

特别的:当byte,short,char三种类型的变量做运算时,结果为int型

class Test{
	public static void main(String[] args) {
		
		byte b1 = 2;
		int i1 = 129;
		//编译不通过
		//byte b2 = b1 + i1;
		int i2 = b1 + i1;
		long l1 = b1 + i1;
		System.out.println(i2);

		float f = b1 + i1;
		System.out.println(f);

		short s1 = 123;
		double d1 = s1;
		System.out.println(d1);//123.0

		//***************特别地*********************
		char c1 = 'a';//97
		int i3 = 10;
		int i4 = c1 + i3;
		System.out.println(i4);

		short s2 = 10;
		//char c2  = c1 + s2;//编译不通过

		byte b2 = 10;
		//char c3 = c1 + b2;//编译不通过
		//short s3 = b2 + s2;//编译不通过
		//short s4 = b1 + b2;//编译不通过
	}
}

2.强制类型转换:自动类型提升运算的逆运算
①要使用强转符()
②注意,强制类型转换,可能会导致精度损失
容量小的数据类型变量→容量大的数据类型变量,不会丢失原有信息。
容量大的数据类型变量→容量小的数据类型变量,可能会丢失原有信息。

class Test1 {
	public static void main(String[] args) {
		double d1 = 12.9;
		//精度损失举例1
		int i1 = (int)d1;//截断操作
		System.out.println(i1);

		//没有精度损失
		long l1 = 123;
		short s2 = (short)l1;
		
		//精度损失举例2
		int i2 = 128;
		byte b = (byte)i2;
		System.out.println(b);//-128
	}
}
发布了1 篇原创文章 · 获赞 0 · 访问量 7

猜你喜欢

转载自blog.csdn.net/qq_45766098/article/details/104106271