关于Java中保留小数位的几种汇总

Java中的保留小数位的几种方法:

1. 使用java.math.BigDecimal

BigDecimal 计算和保留小数位是在Java最常用的,也是在财务或者是数据分析中比较重要的方法,要是计算不准确,会少很多钱的哦!
具体的方法有:

BigDecimal.setScale(int newScale, int roundingMode);//设置格式化小数位
//在这个方法中int roundingMode具体的参数如下
BigDecimal.ROUND_UP;//向远离0的方向舍入,进位处理,2.35变为2.4
BigDecimal.ROUND_DOWN;//向零方向舍入,3.35变为3.3
BigDecimal.ROUND_CEILING;//向正无穷方向舍入
BigDecimal.ROUND_FLOOR;//向负无穷方向舍入 
BigDecimal.ROUND_HALF_UP;//向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6 
BigDecimal.ROUND_HALF_DOWN;//向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5 
BigDecimal.ROUND_HALF_EVEN;//向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP ,如果是偶数,使用 
BigDecimal.ROUND_UNNECESSARY;//计算结果是精确的,不需要舍入模式 
2. 使用java.text.DecimalFormat
public static String format2(double value) {
     DecimalFormat df = new DecimalFormat("0.00");
     df.setRoundingMode(RoundingMode.HALF_UP);
     return df.format(value);
}
3. 使用java.text.NumberFormat
public static String format3(double value) {
     NumberFormat nf = NumberFormat.getNumberInstance();
     nf.setMaximumFractionDigits(2);
     /*
      * setMinimumFractionDigits设置成2
      * 
      * 如果不这么做,那么当value的值是100.00的时候返回100
      * 
      * 而不是100.00
      */
     nf.setMinimumFractionDigits(2);
     nf.setRoundingMode(RoundingMode.HALF_UP);
     /*
      * 如果想输出的格式用逗号隔开,可以设置成true
      */
     nf.setGroupingUsed(false);
     return nf.format(value);
}
4. 使用java.util.Formatter
public static String format4(double value) {
 /*
  * %.2f % 表示 小数点前任意位数 2 表示两位小数 格式后的结果为 f 表示浮点型
  */
 return new Formatter().format("%.2f", value).toString();
}
5. 使用String.format
public static String format5(double value) {
      return String.format("%.2f", value).toString();
}
扩展知识

String.format 作为文本处理工具,为我们提供强大而丰富的字符串格式化功能。

占位符格式为: %[index$][标识]*[最小宽度][.精度]转换符

double num = 123.4567899;
System.out.print(String.format("%f %n", num)); // 123.456790 
System.out.print(String.format("%a %n", num)); // 0x1.edd3c0bb46929p6 
System.out.print(String.format("%g %n", num)); // 123.457

可用标识:

  -,在最小宽度内左对齐,不可以与0标识一起使用。
  0,若内容长度不足最小宽度,则在左边用0来填充。
  #,对8进制和16进制,8进制前添加一个0,16进制前添加0x。
  +,结果总包含一个+或-号。
  空格,正数前加空格,负数前加-号。
  ,,只用与十进制,每3位数字间用,分隔。
  (,若结果为负数,则用括号括住,且不显示符号。

可用转换符:

  b,布尔类型,只要实参为非false的布尔类型,均格式化为字符串true,否则为字符串false。
  n,平台独立的换行符, 也可通过System.getProperty("line.separator")获取。
  f,浮点数型(十进制)。显示9位有效数字,且会进行四舍五入。如99.99。
  a,浮点数型(十六进制)。
  e,指数类型。如9.38e+5。
  g,浮点数型(比%f,%a长度短些,显示6位有效数字,且会进行四舍五入)

你可能感兴趣的:(java)