关于Java中保留小数位的几种汇总
程序员文章站
2022-07-15 09:35:16
...
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位有效数字,且会进行四舍五入)
上一篇: js运算小数问题
下一篇: c语言十进制转二进制,八进制的最快方法
推荐阅读