java四舍五入及注意点
2024-10-07 07:53:16
package com.example.newtest.test; import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.text.NumberFormat; public class DoubleTest {
/**
* Math.round()
*
* @param d
* @return
*/
public static double formatDouble1(double d) {
return (double) Math.round(d * 100) / 100;
} /**
* new BigDecimal().setScale()
*
* @param d
* @return
*/
public static double formatDouble2(double d) {
// 旧方法,已经不再推荐使用
// BigDecimal bg = new BigDecimal(d).setScale(2, BigDecimal.ROUND_HALF_UP);
// 新方法,如果不需要四舍五入,可以使用RoundingMode.DOWN
BigDecimal bg = new BigDecimal(d).setScale(2, RoundingMode.UP);
return bg.doubleValue();
} /**
* NumberFormat().format()
*
* @param d
* @return
*/
public static String formatDouble3(double d) {
NumberFormat nf = NumberFormat.getNumberInstance();
// 保留两位小数
nf.setMaximumFractionDigits(2);
// 如果不需要四舍五入,可以使用RoundingMode.DOWN
nf.setRoundingMode(RoundingMode.UP);
return nf.format(d);
} /**
* DecimalFormat().format
*
* @param d
* @return
*/
public static String formatDouble4(Double d) {
//0表示如果该位置的数值无论大于0还是等于0都要显示占位;#表示如果该位置的数值大于0显示数值,如果等于0则不显示.
//DecimalFormat("0.#0")这种情况下会抛异常
//解读:#.00 表示两位小数 #.0000四位小数 以此类推…
DecimalFormat df = new DecimalFormat("#.00");
df.setRoundingMode(RoundingMode.HALF_UP); //默认是HALF_EVEN
String res;
res = df.format(new BigDecimal(d)); //18.14
res = df.format(new BigDecimal(d.toString())); //18.15
res = df.format(BigDecimal.valueOf(d)); //18.15
//运行以上代码可以看到,结果是不一样的
//原因: 使用参数为float或double的BigDecimal创建对象会丢失精度,因此不要使用参数为float或double的BigDecimal创建对象
//解决办法:
//使用BigDecimal(String val)的构造方法创建对象
//使用使用BigDecimal的valueOf(double val)方法创建对象
return res;
} /**
* String.format()格式化输出
* 解读: %.2f 中 %. 表示 小数点前任意位数 2 表示两位小数 格式后的结果为f 表示浮点型。
* @param d
* @return
*/
public static String formatDouble5(double d) {
return String.format("%.2f", d);
} public static void main(String[] args) {
double d = 18.145;
System.out.println(formatDouble1(d));
System.out.println(formatDouble2(d));
System.out.println(formatDouble3(d));
System.out.println(formatDouble4(d));
System.out.println(formatDouble5(d));
}
}
补充: BigDecimal.ROUND_HALF_XXX的各种用法
在银行、帐户、计费等领域,BigDecimal提供了精确的数值计算。其中8种舍入方式值得掌握。 1、ROUND_UP 舍入远离零的舍入模式。 在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)。 注意,此舍入模式始终不会减少计算值的大小。 2、ROUND_DOWN 接近零的舍入模式。 在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)。 注意,此舍入模式始终不会增加计算值的大小。 3、ROUND_CEILING 接近正无穷大的舍入模式。 如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同; 如果为负,则舍入行为与 ROUND_DOWN 相同。 注意,此舍入模式始终不会减少计算值。 4、ROUND_FLOOR 接近负无穷大的舍入模式。 如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同; 如果为负,则舍入行为与 ROUND_UP 相同。 注意,此舍入模式始终不会增加计算值。 5、ROUND_HALF_UP 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。 如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同。 注意,这是我们大多数人在小学时就学过的舍入模式(四舍五入)。 6、ROUND_HALF_DOWN 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。 如果舍弃部分 > 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(五舍六入)。 7、ROUND_HALF_EVEN 银行家舍入法 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。 如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同; 如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。 注意,在重复进行一系列计算时,此舍入模式可以将累加错误减到最小。 此舍入模式也称为“银行家舍入法”,主要在美国使用。四舍六入,五分两种情况。 如果前一位为奇数,则入位,否则舍去。 以下例子为保留小数点1位,那么这种舍入方式下的结果。 1.15>1.2 1.25>1.2 8、ROUND_UNNECESSARY 断言请求的操作具有精确的结果,因此不需要舍入。 如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。 因为我们是属于互联网金融行业,所有在进行计算的时候尽量使用ROUND_HALF_EVEN 银行家舍入法
最新文章
- 在iOS中实现一个简单的画板App
- sql语句修改字段长度
- pdo 整套类的封装,保存修改查询
- windows编程:资源和播放声音
- 【转】(笔记)CANopen协议【CANFestival】移植方法
- Oracle数据库备份与还原操作具体步骤
- 在VPS上部署fq环境
- Magento PDF发票,支持中文,以及修改的办法
- 锋利的jQuery
- 软件工程个人项目-Word frequency program by11061167龚少波
- LVS 之 DR model arp_announce arp_ignore转
- Enable HTTPS in Spring Boot
- HW4.40
- [AWS S3] Hosting a Static Website on Amazon S3
- DRP之Oracle_11g数据库安装
- 【SqlServer】【问题收集】阻止保存要求重新创建表的更改
- java 保留字段volatile、transient、native、synchronized
- KNN Python实现
- incomplete type is not allowed ofstream
- log4j的一些参数说明
热门文章
- LNMP 架构安装部署
- PHP实现最简单爬虫原型
- 【POJ3162】Walking Race 树形dp+单调队列+双指针
- vue和cordova项目整合打包,并实现vue调用android的相机的demo
- NOIP2016提高A组五校联考2总结
- tf.concat( )和tf.stack( )
- VS2017 + EF + MySQL 环境配置
- 22.从上往下打印二叉树(python)
- python 从入门到实践 第三章
- 15. ClustrixDB 管理数据分布