java实现double的精确计算和四舍五入

 

Java中的简单浮点数类型float和double不能够进行运算。不光是Java,在其它很多编程语言中也有这样的问题。在大多数情况下,计算的结果是准确的,但是多试几次(可以做一个循环)就可以试出类似上面的错误。现在终于理解为什么要有BCD码了。



这个问题相当严重,如果你有9.999999999999元,你的计算机是不会认为你可以购买10元的商品的。



在有的编程语言中提供了专门的货币类型来处理这种情况,但是Java没有。现在让我们看看如何解决这个问题。







四舍五入



我们的第一个反应是做四舍五入。Math类中的round方法不能设置保留几位小数,我们只能象这样(保留两位):



public double round(double value){



    return Math.round(value*100)/100.0;



}



非常不幸,上面的代码并不能正常工作,给这个方法传入4.015它将返回4.01而不是4.02,如我们在上面看到的



4.015*100=401.49999999999994



因此如果我们要做到精确的四舍五入,不能利用简单类型做任何运算



java.text.DecimalFormat也不能解决这个问题:



System.out.println(new java.text.DecimalFormat("0.00").format(4.025));



输出是4.02



java 代码

### 回答1: 在Java中可以使用DecimalFormat类来格式化数字,并且可以设置保留小数位数和不进行四舍五入的方式。下面是一个示例代码: ```java import java.text.DecimalFormat; public class Main { public static void main(String[] args) { double num = 3.141592653589; DecimalFormat df = new DecimalFormat("#.##"); df.setRoundingMode(RoundingMode.DOWN); String result = df.format(num); System.out.println(result); } } ``` 这段代码输出的结果为: ``` 3.14 ``` 其中,`#`表示数字占位符,`.`表示小数点,`##`表示保留两位小数,`setRoundingMode(RoundingMode.DOWN)`设置不进行四舍五入。 ### 回答2: 在Java中,我们通常使用BigDecimal类来控制数字的精度并避免四舍五入。以下是一种方法来保留两位小数而不进行四舍五入的方式: 1. 创建一个BigDecimal对象,将要保留两位小数的数字作为构造函数的参数传入。 ```java BigDecimal number = new BigDecimal("3.14159"); ``` 2. 使用setScale()方法设置要保留的小数位数和舍入模式。通过指定舍入模式为BigDecimal.ROUND_DOWN,可以实现直接截断小数位而不进行四舍五入。 ```java number = number.setScale(2, BigDecimal.ROUND_DOWN); ``` 3. 最后,可以通过调用doubleValue()方法将BigDecimal对象转换为double类型的值,以便进行后续使用。 ```java double result = number.doubleValue(); ``` 使用以上方法,我们可以保留两位小数并避免四舍五入。 需要注意的是,由于浮点数的局限性,使用double类型可能存在精度丢失的问题。因此,在需要精确计算的情况下,建议使用BigDecimal类进行数字处理。 ### 回答3: 在Java中,如果我们想要保留两位小数但不进行四舍五入,我们可以使用以下几种方法: 1. 使用DecimalFormat类:这个类提供了很多方法来格式化数字,我们可以使用它来指定保留小数位数的规则。在这种情况下,我们可以使用setRoundingMode()方法来设置舍入模式为HALF_UP。这样,当小数部分大于等于0.5,就会进行进位,否则直接截断。 下面是一个示例代码: ```java import java.text.DecimalFormat; public class Main { public static void main(String[] args) { double number = 3.14567; DecimalFormat df = new DecimalFormat("#.##"); df.setRoundingMode(RoundingMode.HALF_UP); System.out.println(df.format(number)); } } ``` 2. 使用BigDecimal类:BigDecimal类提供了高精度的浮点数运算。我们可以使用setScale()方法来指定保留小数位数的规则。同样地,在这种情况下,我们可以使用ROUND_HALF_UP来设置舍入模式为HALF_UP。 下面是一个示例代码: ```java import java.math.BigDecimal; import java.math.RoundingMode; public class Main { public static void main(String[] args) { double number = 3.14567; BigDecimal bd = new BigDecimal(number); bd = bd.setScale(2, RoundingMode.HALF_UP); System.out.println(bd); } } ``` 通过使用DecimalFormat类或BigDecimal类,我们可以实现保留两位小数但不四舍五入的效果。以上是两种常用的方法,你可以根据实际情况选择适合自己的方式。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值