java的几种保留小数位数的方法

https://blog.csdn.net/qq_48736958/article/details/115787037?spm=1001.2101.3001.6650.4&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-4-115787037-blog-121975948.pc_relevant_antiscanv2&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-4-115787037-blog-121975948.pc_relevant_antiscanv2&utm_relevant_index=6

java的几种保留小数位数的方法

法一:DecimalFormat

public class DecimalFormatDemo {
    public static void main(String[] args) {
        double decimal=2.15545422;
        DecimalFormat df=new DecimalFormat("#.0000");
        String format = df.format(decimal);
        double v = Double.parseDouble(format);
        System.out.println(v);
    }
}

法二:String.format

public class DecimalFormatDemo {
    public static void main(String[] args) {
        double decimal=2.15555422;
        String format = String.format("%.3f", decimal);
        double v = Double.parseDouble(format);
        System.out.println(v);
    }
}

法三:NumberFormat

public class DecimalFormatDemo {
    public static void main(String[] args) {
        double decimal=2.15555422;
        /*DecimalFormat df=new DecimalFormat("#.0000");
        String format = df.format(decimal);
        double v = Double.parseDouble(format);
        System.out.println(v);*/
        /*String format = String.format("%.3f", decimal);
        double v = Double.parseDouble(format);
        System.out.println(v);*/
        NumberFormat nf=NumberFormat.getNumberInstance();
        nf.setMaximumFractionDigits(3);
        String format = nf.format(decimal);
        double v = Double.parseDouble(format);
        System.out.println(v);
    }
}

法四:BigDecimal

  • ROUND_UP
    只要保留位数之后有一位为0就进位,且与正负无关
public class DecimalFormatDemo {
    public static void main(String[] args) {
        BigDecimal a = new BigDecimal(3.6666666666);
        BigDecimal b = new BigDecimal(-3.650000001);
        System.out.println(a.setScale(2,BigDecimal.ROUND_UP));
        System.out.println(b.setScale(2,BigDecimal.ROUND_UP));
    }
}
 3.660000001——>3.67
 3.666666666——>3.67
 -3.65000001——>-3.66
 -3.65000000——>3.65
  • ROUND_DOWN
    向下保留,不管保留位数后面是多少,统统舍去
public class DecimalFormatDemo {
    public static void main(String[] args) {
        BigDecimal a = new BigDecimal(3.66666666);
        BigDecimal b = new BigDecimal(-3.66666666);
        System.out.println(a.setScale(2,BigDecimal.ROUND_DOWN));
        System.out.println(b.setScale(2,BigDecimal.ROUND_DOWN));
    }
}
3.66
-3.66
  • ROUND_CEILING 向正无穷方向舍入
public class DecimalFormatDemo {
    public static void main(String[] args) {
        BigDecimal a = new BigDecimal(3.66666666);
        BigDecimal b = new BigDecimal(-3.66666666);
        System.out.println(a.setScale(2,BigDecimal.ROUND_CEILING));
        System.out.println(b.setScale(2,BigDecimal.ROUND_CEILING));
    }
}
3.67
-3.66
  • ROUND_FLOOR 向负无穷方向舍入
public class DecimalFormatDemo {
    public static void main(String[] args) {
        BigDecimal a = new BigDecimal(3.66666666);
        BigDecimal b = new BigDecimal(-3.66666666);
        System.out.println(a.setScale(2,BigDecimal.ROUND_FLOOR));
        System.out.println(b.setScale(2,BigDecimal.ROUND_FLOOR));
    }
}
3.66
-3.67
  • ROUND_HELF_UP:数字保留法(四舍五入)
public class DecimalFormatDemo {
    public static void main(String[] args) {
        BigDecimal a = new BigDecimal(3.66666666);
        BigDecimal b = new BigDecimal(-3.66666666);
        System.out.println(a.setScale(2,BigDecimal.ROUND_HALF_DOWN));
        System.out.println(b.setScale(2,BigDecimal.ROUND_HALF_DOWN));
    }
}
3.67
-3.67
  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java中的double类型默认保留15到17位小,但在进行运算时,结果可能会被截断或舍入到更少的小数位。如果需要控制输出的小数位,可以使用DecimalFormat类或String.format()方法来格式化输出。例如,保留两位小可以使用以下代码: ``` double num = 1.23456; System.out.println(String.format("%.2f", num)); ``` 输出结果为:1.23 ### 回答2: Java中,double类型默认保留15位小。 在Java中,double是一种浮点据类型,用于存储小或具有小部分的值。它占用8个字节(64位)的空间,可以表示非常大或非常小的值。 当我们打印或显示一个double类型的值时,默认情况下会保留15位有效字。这意味着在打印时,最多可以显示15位有效字,包括小数点前的字和小数点后的字。当小数点后的位超过15位时,可能会出现舍入误差。 例如,当我们使用以下代码打印一个double类型的值时: double number = 3.14159265358979323846; System.out.println(number); 输出结果将会是:3.141592653589793 这里,输出结果保留了15位有效字,即小数点后的6位。如果我们将number赋值为一个更长的值,比如3.1415926535897932384626433832795028841,同样使用上述代码打印,输出结果依然是:3.141592653589793 因此,double类型默认保留15位小。但需要注意的是,这只是在打印或显示时的默认行为,double类型的变量在进行计算时可能会出现舍入误差,因为不能精确地表示所有的实。如果需要更高的精度和准确性,可以使用Java中的BigDecimal类来处理。 ### 回答3: Java中,double类型默认保留小数点后15位。这是由于Java的double类型采用IEEE 754标准的64位双精度浮点表示法,其中52位用于表示小部分。根据这个标准,double类型的有效位为15到17位,因此默认情况下,Java会将double类型的保留小数点后15位。 需要注意的是,尽管double类型可以表示较大范围的值,但由于浮点的存储方式和运算特性,它在表示和计算精确度上存在一定的限制。在进行浮点计算时,可能会出现舍入误差和精度损失的情况,因此在需要精确计算的场景下,推荐使用BigDecimal类进行计算。 如果想要控制double类型的输出小数位,可以使用格式化字符串或DecimalFormat类来实现。例如,可以使用String.format方法或System.out.printf方法来指定小数位的格式化输出,也可以使用DecimalFormat类提供的方法来设置小数位和进位方式。这样就可以根据具体需求来控制double类型值的输出精度。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值