JAVA中【取整】和【四舍五入】的方法

原创 2011年01月11日 14:52:00

===================================================

        BigDecimal b = new BigDecimal(9.655 );
        //double f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
        double f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();

        System.out.println("f1=" + f1);//f1=9.65
        BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP);
        System.out.println("mData=" + mData);//mData=9.66

public BigDecimal(double val)

    将 double 转换为 BigDecimal,后者是 double 的二进制浮点值准确的十进制表示形式。返回的 BigDecimal 的标度是使 (10scale × val) 为整数的最小值。

    注:

       1. 此构造方法的结果有一定的不可预知性。有人可能认为在 Java 中写入 new BigDecimal(0.1) 所创建的 BigDecimal 正好等于 0.1(非标度值 1,其标度为 1),但是它实际上等于 0.1000000000000000055511151231257827021181583404541015625。这是因为 0.1 无法准确地表示为 double(或者说对于该情况,不能表示为任何有限长度的二进制小数)。这样,传入 到构造方法的值不会正好等于 0.1(虽然表面上等于该值)。
       2. 另一方面,String 构造方法是完全可预知的:写入 new BigDecimal("0.1") 将创建一个 BigDecimal,它正好 等于预期的 0.1。因此,比较而言,通常建议优先使用 String 构造方法。
       3. 当 double 必须用作 BigDecimal 的源时,请注意,此构造方法提供了一个准确转换;它不提供与以下操作相同的结果:先使用 Double.toString(double) 方法,然后使用 BigDecimal(String) 构造方法,将 double 转换为 String。要获取该结果,请使用 static valueOf(double) 方法。

    参数:
        val - 要转换为 BigDecimal 的 double 值。
    抛出:
        NumberFormatException - 如果 val 为无穷大或 NaN。

========================================================================

import java.text.DecimalFormat;

  double d1 = 0.567;
        DecimalFormat df=new DecimalFormat("#.##");
        System.out.println("df.format(0.565)=" + df.format(0.565));//0.56
        System.out.println("df.format(0.567)=" + df.format(d1));//0.57

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

java取整和java四舍五入方法

[转]http://www.cnblogs.com/xd502djj/archive/2011/07/21/2112683.html import java.math.BigDecimal; i...

java取整和java四舍五入方法

import java.math.BigDecimal;  import java.text.DecimalFormat; public class TestGetInt{  public ...

java取整和java四舍五入方法

http://blog.csdn.net/kankan_summer/article/details/5744576 文章出自http://www.cujava.com ...

java取整和java四舍五入方法

double i=2, j=2.1, k=2.5, m=2.9;     System.out.println("舍掉小数取整:Math.floor(2)=" + (int)Math.floor(i...

java取整和java四舍五入方法

mport java.math.BigDecimal;  import java.text.DecimalFormat; public class TestGetInt{  public s...

java取整和java四舍五入方法

转自:http://jie2workjava.iteye.com/blog/345224java取整和java四舍五入方法: import java.math.BigDecimal; import ...

java取整和java四舍五入方法

import java.math.BigDecimal; import java.text.DecimalFormat; public class TestGetInt{ public st...

java取整和java四舍五入方法

import java.math.BigDecimal;  import java.text.DecimalFormat; public class TestGetInt{  public stat...

java取整和java四舍五入方法 BigDecimal.setScale()方法详解.

内容: import java.math.BigDecimal;  import java.text.DecimalFormat; public class TestGetInt{    ...

java取整和java四舍五入方法 BigDecimal.setScale()方法详解.

内容: import Java.math.BigDecimal;  import java.text.DecimalFormat; public class TestGetInt{    ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)