Java中让浮点型数据保留两位小数的四种方法

您所在的位置:网站首页 float不保留小数 Java中让浮点型数据保留两位小数的四种方法

Java中让浮点型数据保留两位小数的四种方法

2024-04-29 22:41| 来源: 网络整理| 查看: 265

hello,你好呀,我是灰小猿,一个超会写bug的程序猿!

今天在进行开发的过程中遇到了一个小问题,是关于如何将double类型的数据保留两位小数。突然发现这方面有一点欠缺,就来总结一下。

一、String类的方式

该方式是是使用String的format()方法来实现的,该方法的作用就是规范数据的格式,第一个参数传入一个字符串来表示输出的数据格式,如保留两位小数就使用“%.2f”,第二个参数是要进行格式化的数据。实例如下:

代码语言:javascript复制 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 的一个具体子类,操作和使用起来都比较方便。在使用的时候需要实例化这个类,构造函数中传入数据的格式类型。

其中各个符号的含义如下:

使用案例如下:

代码语言:javascript复制/** * 测试保留两位小数 */ public static void testDoubleToTwo() { /** *DecimalFormat类 */ DecimalFormat decimalFormat = new DecimalFormat("#.00"); String ans_3 = decimalFormat.format(testDounle_01); System.out.println(ans_3); }三、BigDecimal类进行数据处理

java.math包中提供的API类BigDecimal,是用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。但是也可以用来定义小数点后两位,但是使用起来比较麻烦,不太推荐使用。

代码语言:javascript复制 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类似,但是使用起来也是十分的麻烦。

代码语言:javascript复制 double testDounle_01 = 123.456; float testFloat_01 = 456.125f; /** * NumberFormat类进行数据处理 * */ NumberFormat numberInstance = NumberFormat.getNumberInstance(); // 设置最大小数点位数 numberInstance.setMaximumFractionDigits(2); // 设置数据舍入类型 numberInstance.setRoundingMode(RoundingMode.HALF_UP); System.out.println(numberInstance.format(testDounle_01));总结一下

对于将浮点型数据保留两位小数,我比较推荐的还是前两种方法,或者是直接使用String.format()方法,



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3