数据类型转换

Java程序中要求参与的计算的数据,必须要保证数据类型的一致性,如果数据类型不一致将发生类型的转换。

  1. 自动转换
    将 取值范围小的类型 自动提升为 取值范围大的类型 。
public static void main(String[] args) {
	int i = 1;
	byte b = 2;
	// byte x = b + i; // 报错
	//int类型和byte类型运算,结果是int类型
	int j = b + i;
	System.out.println(j);
}
  • 转换原理图解
    byte 类型内存占有1个字节,在和 int 类型运算时会提升为 int 类型 ,自动补充3个字节,因此计算后的结果还是 int 类型。
  • java实现基本类型互转工具类_java实现基本类型互转工具类

  • 转换规则
    范围小的类型向范围大的类型提升, byte、short、char 运算时直接提升为 int 。
byte、short、char‐‐>int‐‐>long‐‐>float‐‐>double
  1. 强制转换
    将 1.5 赋值到 int 类型变量会发生什么?产生编译失败,肯定无法赋值。int i = 1.5; // 错误 double 类型内存8个字节, int 类型内存4个字节。 1.5 是 double 类型,取值范围大于 int 。可以理解为 double 是8升的水壶, int 是4升的水壶,不能把大水壶中的水直接放进小水壶去。
    想要赋值成功,只有通过强制类型转换,将 double 类型强制转换成 int 类型才能赋值。
    强制类型转换:将 取值范围大的类型 强制转换成 取值范围小的类型 。
    比较而言,自动转换是Java自动执行的,而强制转换需要我们自己手动执行。
    转换格式:数据类型 变量名 = (数据类型)被转数据值; 将 1.5 赋值到 int 类型,代码修改为:
// double类型数据强制转成int类型,直接去掉小数点。
int i = (int)1.5;

同样道理,当一个 short 类型与 1 相加,我们知道会类型提升,但是还想给结果赋值给short类型变量,就需要强制转换。

public static void main(String[] args) {
	//short类型变量,内存中2个字节
	short s = 1;
	/*
	出现编译失败
	s和1做运算的时候,1是int类型,s会被提升为int类型
	s+1后的结果是int类型,将结果在赋值会short类型时发生错误
	short内存2个字节,int类型4个字节
	必须将int强制转成short才能完成赋值
	*/
	s = s + 1;//编译失败
	s = (short)(s+1);//编译成功
}

转换图解

java实现基本类型互转工具类_强制转换_02

强制类型转换
1. 特点:代码需要进行特殊的格式处理,不能自动完成。
2. 格式:范围小的类型 范围小的变量名 = (范围小的类型) 原本范围大的数据;

强烈注意
1. 强制类型转换一般不推荐使用,因为有可能发生精度损失、数据溢出。
2. byte/short/char这三种类型都可以发生数学运算,例如加法“+”.
3. byte/short/char这三种类型在运算的时候,都会被首先提升成为int类型,然后再计算。
4. boolean类型不能发生数据类型转换

public class Demo02DataType {
	public static void main(String[] args) {
		// 左边是int类型,右边是long类型,不一样
		// long --> int,不是从小到大
		// 不能发生自动类型转换!
		// 格式:范围小的类型 范围小的变量名 = (范围小的类型) 原本范围大的数据;
		int num = (int) 100L;
		System.out.println(num);
		
		// long强制转换成为int类型
		int num2 = (int) 6000000000L;
		System.out.println(num2); // 1705032704
		
		// double --> int,强制类型转换
		int num3 = (int) 3.99;
		System.out.println(num3); // 3,这并不是四舍五入,所有的小数位都会被舍弃掉
		
		char zifu1 = 'A'; // 这是一个字符型变量,里面是大写字母A
		System.out.println(zifu1 + 1); // 66,也就是大写字母A被当做65进行处理
		// 计算机的底层会用一个数字(二进制)来代表字符A,就是65
		// 一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字
		
		byte num4 = 40; // 注意!右侧的数值大小不能超过左侧的类型范围
		byte num5 = 50;
		// byte + byte --> int + int --> int
		int result1 = num4 + num5;
		System.out.println(result1); // 90
		
		short num6 = 60;
		// byte + short --> int + int --> int
		// int强制转换为short:注意必须保证逻辑上真实大小本来就没有超过short范围,否则会发生数据溢出
		short result2 = (short) (num4 + num6);
		System.out.println(result2); // 100
	}
}