java数字格式化-DecimalFormat的用法

DecimalFormat 是 NumberFormat 的一个具体子类,用于格式化十进制数字。
DecimalFormat 包含一个模式 和一组符号

符号含义:

0 一个数字

一个数字,不包括 0

. 小数的分隔符的占位符

, 分组分隔符的占位符

; 分隔格式。

  • 缺省负数前缀。

% 乘以 100 和作为百分比显示

? 乘以 1000 和作为千进制货币符显示;用货币符号代替;如果双写,用

国际货币符号代替。如果出现在一个模式中,用货币十进制分隔符代

替十进制分隔符。

X 前缀或后缀中使用的任何其它字符,用来引用前缀或后缀中的特殊字符。

例子:

DecimalFormat df1 = new DecimalFormat(“0.0”);

DecimalFormat df2 = new DecimalFormat("#.#");

DecimalFormat df3 = new DecimalFormat(“000.000”);

DecimalFormat df4 = new DecimalFormat("###.###");

System.out.println(df1.format(12.34));

System.out.println(df2.format(12.34));

System.out.println(df3.format(12.34));

System.out.println(df4.format(12.34));

结果:

12.3

12.3

012.340

12.34

一、DecimalFormat四舍五入的坑

1.1 有时候我们在处理小数保留几位小数时,想到了DecimalFormat这个类的使用,百度搜一把可能用到以下方式。

 1     public static void main(String[] args) {
 2         String str="3.145";
 3         System.out.println(round1(str));
 4     }
 5 
 6     static String round1(String str){
 7         double a=Double.parseDouble(str);
 8         DecimalFormat df=new DecimalFormat("###.00");
 9         return df.format(a);
10     }

复制代码
复制代码
  1.2 初看好像没什么问题,四舍五入保留两位小数,最后输出3.15。当然精度要求不高,也无需计较。当涉及到精确统计时,这里的坑来了将上面的字符串改为“5”前面为奇数,如“3.155”,就瓜了,输出3.15。显然这里没满足要求,不是我们学校里的四舍五入。再上一段代码。

1     static String round2(String str){
2          double a=Double.parseDouble(str);
3          DecimalFormat df=new DecimalFormat("###.00");
4          df.setRoundingMode(RoundingMode.HALF_UP);
5          return df.format(a);
6     }

这里可以看到这个setRoundingMode()方法可以设定四舍五入的模式,原来四舍五入不光有我们学校里学的那种,还有其他模式。DecimalFormat默认情况下,它使用 RoundingMode.HALF_EVEN,此舍入模式也称为“银行家舍入法”,主要在美国使用。RoundingMode.HALF_UP这个模式才是我们学校里学的标准四舍五入模式。以上代码虽然舍了学校型模式仍然不准确,应该将double类型改为BigDecimal类型。

二、学校型四舍五入几种正确使用

2.1 String直接格式化

1 static String round3(String str){
2 double d=Double.parseDouble(str);
3 return String.format("%.2f",d);
4 }


2.2 BigDecimal结合DecimalFormat,BigDecimal比较好性能,数据处理量大不建议使用。

1     static String round4(String str){
2          BigDecimal bigDecimal=new BigDecimal(str);
3          DecimalFormat df=new DecimalFormat("###.00");
4          df.setRoundingMode(RoundingMode.HALF_UP);
5          return df.format(bigDecimal);
6     }

2.3 BigDecimal单独使用,这个类也自带舍入模式设定方法。

1     static String round5(String str){
2          BigDecimal bigDecimal=new BigDecimal(str);
3          return String.valueOf(bigDecimal.setScale(2,RoundingMode.HALF_UP));
4     }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值