利用BigDecimal解决浮点数精度问题

本文介绍了在遇到浮点数精度问题时,如何利用BigDecimal进行高精度计算。通过示例代码展示了BigDecimal的使用,并强调了使用String构造方法以避免精度损失的重要性。同时提到了BigDecimal运算的性能开销及配合NumberFormat进行格式化输出的功能。
摘要由CSDN通过智能技术生成

今天使用两个浮点数进行相加的时候出现了精度损失问题,于是寻求解决方法,查询资料得知可以用BigDecimal来解决精度问题。

代码在此

public static void main(String[] args) {
	double a = 0.009;
	double b = 0.001;
	System.out.println("浮点数进行数据运算:");
	
	System.out.println(" a = " + a);
	System.out.println(" c = " + b);
	System.out.println(" a + b = " + (a + b));
	System.out.println(" a - b = " + (a - b));
	System.out.println(" a * b = " + (a * b));
	System.out.println(" a / b = " + (a / b));
	System.out.println();
	
	System.out.println("使用BigDecimal解决精度问题:");
	BigDecimal x = new BigDecimal("0.009");
	BigDecimal y = new BigDecimal("0.001");
	System.out.println(" x = " + x);
	System.out.println(" y = " + y);
	System.out.println(" x + y = " + x.add(y));
	System.out.pri
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值