java运算int转double_Java数值类型之间转换

Java之间的数值转换如图所示,实心箭头代表无数据丢失,虚线箭头代表可能丢失

a7795296311097a4fe11383027215f82.png

例如:123456789是一个大的整数,包含的位数比float类型能够表达的位数多,但这个数转换为float类型时,将会得到同样大小的结果,但却失去了一定的精度。

int n = 123456789;

float f =n; //f is 1.23456792E8

当转换前后两个数进行二元操作时(例如n+f,n为整数,f为浮点数),则先将两个操作数转换为同一个类型,再进行计算。

转换规则:

--如果两个操作数中有一个是double类型,另一个操作数就会转换为double类型。

--否则,如果其中一个操作数是float类型时,另一个操作数将会转换为float类型。

--否则,如果其中一个操作数是long类型时,另一个操作数将会转换为long类型。

--否则,两个操作数都将会被转换为int类型。

强制转换类型

在Java中允许进行像int转换为double类型或者double转换为int,但有可能丢失一些信息。如像强制转换类型,则需要通过强制类型转换(cast)实现。强制类型转换的语法格式是在圆括号中给出想要转换的目标类型,后面紧跟待转换的变量名

例如

double x = 9.887;

int nx = (int)x;

变量nx的值为9。强制类型转换通过截断小数将浮点值转换为整型。

如果想将浮点数进行舍入运算,以得到最接近的整数,就需要使用Math.round方法:

double x = 9.887;

int nx = (int)Math.round(x);

现在变量nx的值为10.调用round的时候仍然需要使用强制类型转换(int)。原因为:round方法返回结果为long类型,由于存在信息丢失可能性,所以只有使用显式的强制类型转换才能够将long类型转换为int类型。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值