Java基础—数据类型转换

一、数据类型分类
1.基本数据类型
byte、short、int、long、float、double、char、boolean

2.引用数据类型
字符串、数组、类、接口、Lambda

二、数据类型转换
Java程序中要求参与计算的数据,必须要保证数据类型的一致,当数据类型不一致的时候,将会发生数据类型转换。

1.自动类型转换(隐式转换)
【范围从小到大】

自动类型转换的特点:
	代码不需要进行特殊处理,自动完成
	
自动类型转换的规则:
	数据范围从小到大
	
测试实例:

	System.out.println(1024);	//这是一个整数,默认是int类型
	System.out.println(3.14);	//这是一个浮点数,默认是double类型
	System.out.println("============");
	
	//等号左边是long类型,右边是默认的int类型,左右不一样
	// 一个等号代表赋值,将右侧的int常量,交给左侧的long变量进行存储
	// int ---> long,符合了数据范围从小到大的规则
	// 这一行代码发生了自动类型转换。
	long num2 = 200;	//没有后缀L
	System.out.println(num2);	// 200,定义长整型时不加后缀L也可以正常输出
	System.out.println("============");
	
	// 左边是double类型,右边是float类型,左右不一样
	// float ---> double,符合从小到大的规则
	// 也发生了自动类型转换
	double num3 = 2.5F;
	System.out.println(num3);
	System.out.println("============");
	
	// 左边是float类型,右边是long类型,左右不一样
	// long ---> float,范围是float更大一些,符合从小到大的规则
	// 也发生了自动类型转换
	float num4 = 30L;
	System.out.println(num4);	//30.0

2.强制类型转换(显式转换)
【范围从大到小】

特点:
	代码需要进行特殊的格式处理,不能自动完成。
	
格式:
	范围小的类型 范围小的变量名 = (范围小的类型)原本范围大的数据
	
注意事项:
	1.强制类型转换一般不推荐使用,因为有可能发生精度损失、数据溢出。

	2.byte/short/char这三种类型都可以发生数学运算,例如加法"+"

	3.byte/short/char这三种类型在运算的时候,都会被首先提升为int类型,然后再计算。

	4.boolean类型不能发生数据类型转换
	
ASCII编码表(只需要记住三个即可):

	ASCII值				控制字符
	48					0
	65					A
	97					a
	
测试实例:
	//左侧是int,右侧是long,左右不一样
	//long ---> int,不是从小到大
	// 不能发生自动类型转换
	//格式:范围小的类型 范围小的变量名 = (范围小的类型)原本范围大的数据
	int num2 = (int)200L;
	System.out.println(num2);
	
	//long强制转换成为int类型,int最大可以表示21个亿左右
	int num3 = (int)6000000000L;
	System.out.println(num3);	// 1705032704,此时就发生了数据溢出的现象
	
	//double ---> int
	int num4 = (int)3.5;
	System.out.println(num4);	//3,此时发生了精度损失的现象,不是四舍五入,所有的小数位都会被舍弃掉
	
	char zifu1 = 'A'; //这是一个字符型变量,里面是大写字母A
	System.out.println(zifu1 + 1); 	//66,也就是大写字母A被当做65进行处理
	// 计算机的底层会用一个数字(二进制)来代表字符A。就是65
	// 一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字
	
	byte num5 = 40;	// 注意!右侧的数值大小不能超过左侧的类型范围(-127~128)
	byte num6 = 50;
	//byte + byte ---> int + int,所以等号左侧应该是int类型,而不是byte类型
	int result1 = num5 + num6;
	System.out.println(result1);	//90
	
	short num7 = 60;
	//byte + short ---> int + int --->int
	int result2 = num5 + num7;
	//100没超过short的取值范围,所以也可以用short进行接收,使用强制类型转换
	//int强制转换为short。注意必须保证逻辑上真实大小本来就没有超过short范围,否则会发生数据溢出
	short result3 = (short)(num5 + num7);
	System.out.println(result2);	//100
	System.out.println(result3);	//100

3.数字与字符编码表(对照关系表)
ASCII码表:American StandardCode for Information Interchange,美国信息交换标准代码。(48 - ‘0’, 65 - ‘A’, 97 - ‘a’)

Unicode码表:万国码。也是数字和字符的对照关系,开头0-127部分和ASCII完全一样,但是从128开始包含有更多的字符。

测试实例:

	char zifu1 = '1';
	System.out.println(zifu1 + 0);	//49,打印字符1所对应的ASCII值
	
	char zifu2 = 'A';	//其实底层保存的是65数字
	
	char zifu3 = 'c';
	//左侧是int类型,右侧是char类型,
	//char ---> int,范围从小到大
	//发生了自动类型转换
	int num = zifu3;
	System.out.println(num);	//99
	
	char zifu4 = '中';	//正确写法
	System.out.println(zifu4 + 0);	//20013

4.javac编译器的自动类型转换

1.对于byte、short、char三种类型来说,如果右侧赋值的数值没有超过左侧数据类型的取值范围,那么javac编译器将会自动隐含的补上一个(byte)、(short)、(char)

2.如果右侧没有超过左侧的范围,编译器才会自动加上强转

3.如果右侧超过了左侧的范围,编译器会直接报错

5.javac编译器的常量优化
再给变量进行赋值的时候,如果右侧表达式中全部都是常量,那么javac编译器将会直接计算常量表达式的结果。

例如:short result = 1 + 2;
那么编译之后的.class字节码文件中,保存的其实是:short result = 3;

这称为编译器的常量优化。但是如果右侧表达式中存在变量,那么就不能进行这种优化了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值