浮点数加减丢失精度原因剖析

博客通过1.005为例,展示了浮点数在二进制存储中如何导致精度丢失。分析了计算机中double类型的存储结构,解释了精度丢失的原因,并对比了BigDecimal如何避免精度问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里以1.005为例子,模拟二进制存储

1为整数位

 

package baseJava;

import java.math.BigDecimal;
import java.util.HashMap;

public class DoubleTest {
	
	public static void main(String[] args) {
		double decimalPart = 0.005;
		String binaryStr = getBinaryStr(decimalPart);
		System.out.println(binaryStr);
	}
	
	private static String getBinaryStr(double a) {
		BigDecimal aa = new BigDecimal(a+"");
		
		String returnStr = "";
		HashMap<BigDecimal,String> map = new HashMap<>();
		for(;aa.compareTo(BigDecimal.ZERO)!=0;) {
			aa = aa.multiply(new BigDecimal("2"));
			System.out.println(aa);
			if(map.containsKey(aa)) {//key 相同说明已经开始循环
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			}
			map.put(aa, "");
			if(aa.compareTo(BigDecimal.ONE)>=0) {
				returnStr = returnStr +"1";
				aa = aa.subtract(BigDecimal.ONE);
			}else {
				returnStr = returnStr +"0";
			}
			Sys
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值