浅谈Java中浮点型数据保留两位⼩数的四种⽅法
⽬录
⼀、String类的⽅式
⼆、DecimalFormat类
三、BigDecimal类进⾏数据处理
四、NumberFormat类进⾏数据处理
总结⼀下
今天在进⾏开发的过程中遇到了⼀个⼩问题,是关于如何将double类型的数据保留两位⼩数。突然发现这⽅⾯有⼀点⽋缺,就来总结⼀下。
⼀、String类的⽅式
该⽅式是是使⽤String的format()⽅法来实现的,该⽅法的作⽤就是规范数据的格式,第⼀个参数传⼊⼀个字符串来表⽰输出的数据格式,如保留两位⼩数就使⽤“%.2f”,第⼆个参数是要进⾏格式化的数据。
实例如下:
double testDounle_01 = 123.456;
float testFloat_01 = 456.125f;
/**
* 使⽤string类的⽅式
* */
System.out.println("使⽤string类的⽅式");
System.out.println(String.format("%.2f", testDounle_01));
System.out.println(String.format("%.2f", testFloat_01));
⼆、DecimalFormat类
DecimalFormat类主要就是⽤于格式化⼗进制数据的,这个类是NumberFormat 的⼀个具体⼦类,操作和使⽤起来都⽐较⽅便。在使⽤的时候需要实例化这个类,构造函数中传⼊数据的格式类型。
其中各个符号的含义如下:
使⽤案例如下:
/**
* 测试保留两位⼩数
*/
public static void testDoubleToTwo() {
/**
*DecimalFormat类
*/
DecimalFormat decimalFormat = new DecimalFormat("#.00");
String ans_3 = decimalFormat.format(testDounle_01);
bigdecimal除法保留小数System.out.println(ans_3);
}
三、BigDecimal类进⾏数据处理
java.math包中提供的API类BigDecimal,是⽤来对超过16位有效位的数进⾏精确的运算。双精度浮点型变量double可以处理16位有效数。但是也可以⽤来定义⼩数点后两位,但是使⽤起来⽐较⿇烦,不太推荐使⽤。
double testDounle_01 = 123.456;
float testFloat_01 = 456.125f;
/**
* BigDecimal类进⾏数据处理
* */
BigDecimal bigDecimal = new BigDecimal(testDounle_01);
double ans_2 = bigDecimal.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
System.out.println(ans_2);
四、NumberFormat类进⾏数据处理
NumberFormat类是数据格式化类,使⽤该类将浮点数保留⼆进制的⽅法和BigDecimal类似,但是使⽤起来也是⼗分的⿇烦。
double testDounle_01 = 123.456;
float testFloat_01 = 456.125f;
/**
* NumberFormat类进⾏数据处理
* */
NumberFormat numberInstance = NumberInstance();
// 设置最⼤⼩数点位数
numberInstance.setMaximumFractionDigits(2);
// 设置数据舍⼊类型
numberInstance.setRoundingMode(RoundingMode.HALF_UP);
System.out.println(numberInstance.format(testDounle_01));
总结⼀下
对于将浮点型数据保留两位⼩数,我⽐较推荐的还是前两种⽅法,或者是直接使⽤String.format()⽅法,
到此这篇关于浅谈Java中浮点型数据保留两位⼩数的四种⽅法的⽂章就介绍到这了,更多相关Java浮点型保留两位⼩数内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论