文章目录
前言
在Java项目开发中,我遇到了对float或者double类型的数据进行运算之后保留小数位数的情况,初次遇到这个情况做个记录。
一、保留小数位数的需求
在做一个学生管理系统的项目的时候,遇到了计算加权成绩的需求,即需要根据学生所修的课程,以及课程的学分来计算学生的加权学业成绩,在浮点数计算过程中,产生了一长串小数,这显然不是我想存到数据库中的数据,因此需要保留一定位数,这里选择保留两位。
二、Java保留小数位数的方法
1.常用方法
这个问题很常见,也很容易解决,常用的方法有如下几种:
- BigDecimal
- DecimalFormat
- java.util.Formatter
- String.format
下面将分别介绍这四种方法
2.方法详解
2.1、BigDecimal
这种方法是先将double/float类型的数据转换为BigDecimal类型,然后再使用BigDecimal类的setScale方法,设置四舍五入以及保留的小数位数,具体代码如下:
@Test
public void testDouble(){
double num = 3.555555f;
BigDecimal bd = new BigDecimal(num);
bd = bd.setScale(4, RoundingMode.HALF_UP);
// .getClass()获得变量的类型
System.out.println(bd.getClass());
System.out.println(bd);
// 上面转换之后的bd为BigDecimal类型的数据,如果想转换为double,需要使用下面的转换方式。
//.doubleValue将数字转换为double,Double.parseDouble()将字符串转换为double
num = bd.doubleValue();
}
这里的两个打印的输出分别为:
class java.math.BigDecimal
3.5556
2.2、DecimalFormat
DecimalFormat是一种数据格式化方式,首先实例化一个数据格式化方式df,并且指定保留两位小数,然后指定四舍五入的规则,然后使用df.format()即可完成格式化,值得注意的是,df.format()之后得到的结果是String类型的数据。
@Test
public void testDecimalFormat(){
double num = 3.555555f;
DecimalFormat df = new DecimalFormat("0.00");
df.setRoundingMode(RoundingMode.HALF_UP);
System.out.println(df.format(num).getClass());
System.out.println(df.format(num));
// Double.parseDouble将String类型的数据转换为Double类型
num = Double.parseDouble(df.format(num));
}
两处输出为:
class java.lang.String
3.56
2.3、java.util.Formatter
java.util.Formatter方法最为简单,首先实例化一个Formatter对象,指定格式化的类型和数据,然后获得一个Formatter对象,再将这个对象转换为String,再转换为Double就可以啦!
@Test
public void testFormatter(){
Formatter format = new Formatter().format("%.2f", num);
// String.valueOf()和.toString方法都能转换为String,不过String.valueOf()更常用
num = Double.parseDouble(String.valueOf(format));
}
2.4、String.format
这种方法也非常简单,使用String.format()方法将double类型的数据转换为String类型的数据,然后再根据需要变换即可。
@Test
public void testStringFormat(){
String format = String.format("%.2f", num);
System.out.println(format.getClass());
System.out.println(Double.parseDouble(format));
}
两处输出为:
class java.lang.String
3.56
总结
以上就是对Java保留几位小数方法的总结,一共四种方法:BigDecimal、DecimalFormat、java.util.Formatter和String.format,四种方法都很简单且都实现了四舍五入