http://stephen830.javaeye.com/blog/260776本篇介绍了在JAVA中如何对double或者float的浮点数进行精度计算,在JAVA中提供了多种参数来实现精度的不同控制方式。具体例子如下:
-
-
-
-
-
-
- package com.soft4j.utility;
-
- import java.math.BigDecimal;
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- public final class RoundTool {
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- public static double round(double value, int scale, int roundingMode) {
- BigDecimal bd = new BigDecimal(value);
- bd = bd.setScale(scale, roundingMode);
- double d = bd.doubleValue();
- bd = null;
- return d;
- }
-
-
-
-
-
-
-
- public static void main(String[] argc) {
-
-
-
-
- System.out.println(round(12.3401,2,BigDecimal.ROUND_UP));
- System.out.println(round(-12.3401,2,BigDecimal.ROUND_UP));
-
-
-
- System.out.println(round(12.349,2,BigDecimal.ROUND_DOWN));
- System.out.println(round(-12.349,2,BigDecimal.ROUND_DOWN));
-
-
-
- System.out.println(round(12.3401,2,BigDecimal.ROUND_CEILING));
- System.out.println(round(-12.349,2,BigDecimal.ROUND_CEILING));
-
-
-
- System.out.println(round(12.349,2,BigDecimal.ROUND_FLOOR));
- System.out.println(round(-12.3401,2,BigDecimal.ROUND_FLOOR));
-
-
-
- System.out.println(round(12.345,2,BigDecimal.ROUND_HALF_UP));
- System.out.println(round(12.3449,2,BigDecimal.ROUND_HALF_UP));
- System.out.println(round(-12.345,2,BigDecimal.ROUND_HALF_UP));
- System.out.println(round(-12.3449,2,BigDecimal.ROUND_HALF_UP));
-
-
-
- System.out.println(round(12.345,2,BigDecimal.ROUND_HALF_DOWN));
- System.out.println(round(12.3449,2,BigDecimal.ROUND_HALF_DOWN));
- System.out.println(round(-12.345,2,BigDecimal.ROUND_HALF_DOWN));
- System.out.println(round(-12.3449,2,BigDecimal.ROUND_HALF_DOWN));
-
-
-
- System.out.println(round(12.346,2,BigDecimal.ROUND_HALF_EVEN));
- System.out.println(round(12.345,2,BigDecimal.ROUND_HALF_EVEN));
- }
- }
相关文章:
《Double精度的常用设置》
import java.text.DecimalFormat;
import java.math.BigDecimal;
public class Test_Double{
public static void main(String[] args){
//-----方法1--------四舍五入 round对负数是五舍六入
double d_1 = 123.9;
System.out.println("d_1 = "+Math.round(d_1));
//-------方法2------------------
DecimalFormat decfmt = new DecimalFormat("##0.00");
System.out.println(decfmt.format(1.33482222));
//--------方法3--------------
double x = 1.33345;
java.text.NumberFormat formate = java.text.NumberFormat.getNumberInstance();
formate.setMaximumFractionDigits(3);//设定小数最大为数,那么显示的最后会四舍五入的
String m = formate.format(x);
System.out.println(m);
//--------方法4--------------
BigDecimal bd = new BigDecimal(1.234543);
bd = bd.setScale(3,BigDecimal.ROUND_HALF_EVEN);
double d = bd.doubleValue();
System.out.println(d);
//--------取消科学计数法-------------
Double dValue = Double.valueOf("276363652844.8477474");
System.out.println(dValue);
BigDecimal original = new BigDecimal(dValue.doubleValue());
BigDecimal result = original.setScale(2, BigDecimal.ROUND_HALF_DOWN);
String test = result.toString();
System.out.println(test);
}
}
使用Java,double 进行运算时,经常出现精度丢失的问题,总是在一个正确的结果左右偏0.0000**1。 特别在实际项目中,通过一个公式校验该值是否大于0,如果大于0我们会做一件事情,小于0我们又处理其他事情。 这样的情况通过double计算出来的结果去和0比较大小,尤其是有小数点的时候,经常会因为精度丢失而导致程序处理流程出错。
所以一般对double类型进行运算时,做好对结果进行处理,然后拿这个值去做其他事情。
目前总结如下:
/**
* 对double数据进行取精度.
* @param value double数据.
* @param scale 精度位数(保留的小数位数).
* @param roundingMode 精度取值方式.
* @return 精度计算后的数据.
*/
public static double round(double value, int scale,
int roundingMode) {
BigDecimal bd = new BigDecimal(value);
bd = bd.setScale(scale, roundingMode);
double d = bd.doubleValue();
bd = null;
return d;
}
/**
* double 相加
* @param d1
* @param d2
* @return
*/
public double sum(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.add(bd2).doubleValue();
}
/**
* double 相减
* @param d1
* @param d2
* @return
*/
public double sub(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.subtract(bd2).doubleValue();
}
/**
* double 乘法
* @param d1
* @param d2
* @return
*/
public double mul(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.multiply(bd2).doubleValue();
}
/**
* double 除法
* @param d1
* @param d2
* @param scale 四舍五入 小数点位数
* @return
*/
public double div(double d1,double d2,int scale){
// 当然在此之前,你要判断分母是否为0,
// 为0你可以根据实际需求做相应的处理
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.divide
(bd2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}
这样,计算double类型的数据计算问题就可以处理了。
另外补充一下 JavaScript 四舍五入的方法:
小数点问题
Math.round(totalAmount*100)/100 (保留 2 位)
function formatFloat(src, pos)
{
return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
}
希望以上对大家有所帮助,如果说错了,还希望大家给点指正!
(#)
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请
点击举报。