JAVA中数值类型转换

1 问题引入

经常需要将一种数值类型转换为另一种数值类型;
例如1+3.72—>整型+浮点型。结果为4.72没问题,可是会有一些精度的问题。

2 查看问题

请看以下代码:

		int n =  987654321;
	    float f = n;

此时f的值为9.8765434E8
就已经对精度没那么准确了。
所以统计了一下数值类型之间的合法转换:
在这里插入图片描述
因为两个类型相加,先将两个操作数据转换为同一种类型,转换时总会比变成大容量的一方,所以图中是单向箭头。
黑色箭头表示无信息丢失转换。
红色箭头标识可能有精度损失转换。(就像上方的例子)。

3 注意事项

如果两个操作数中有一个是 double 类型,另一个操作数就会转换为 double 类型
否则,如果其中一个操作数是 float 类型,另一个操作数将会转换为 float 类型
否则,如果其中一个操作数是 long 类型,另一个操作数将会转换为 long 类型。
否则,两个操作数都将被转换为 int 类型。
上面只会由小->大转换,那么大->小转换如何呢,可以看一下强制类型转换

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值