> Java > java지도 시간 > Java에서 Double을 계산할 때 반올림 오류를 방지하려면 어떻게 해야 합니까?

Java에서 Double을 계산할 때 반올림 오류를 방지하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-12-22 05:11:14
원래의
447명이 탐색했습니다.

How Can I Avoid Rounding Errors When Calculating with Doubles in Java?

Java 이중 반올림 문제 해결

Java에서 배정밀도 부동 소수점 숫자로 계산을 수행하면 다음과 같은 이유로 예상치 못한 결과가 발생할 수 있습니다. 반올림 오류. 이 문제를 해결하려면 Java의 부동 소수점 연산을 이해하고 적절한 솔루션을 채택하는 것이 중요합니다.

이중 값을 뺄 때 작은 반올림 오류가 누적되어 잘못된 계산이 발생할 수 있습니다. 다음 코드 조각을 고려하십시오.

double tempCommission = targetPremium.doubleValue()*rate.doubleValue()/100d;
double netToCompany = targetPremium.doubleValue() - tempCommission;
double dCommission = request.getPremium().doubleValue() - netToCompany;
로그인 후 복사

이 예에서 예상 커미션 결과는 877.85이지만 반올림 오류로 인해 계산 결과는 877.8499999999999가 됩니다.

해결책: 사용 BigDecimal

정확한 계산을 위해서는 java.math.BigDecimal을 사용하는 것이 좋습니다. 이 클래스는 이중 데이터 유형의 한계를 해결하는 정밀 부동 소수점 연산을 제공합니다.

BigDecimal을 사용하여 코드의 마지막 줄을 다시 작성합니다.

BigDecimal commission = premium.subtract(netToCompany);
로그인 후 복사

이 접근 방식은 반올림 오류를 제거하고 올바른 결과를 생성합니다. 결과:

System.out.println(commission + " = " + premium + " - " + netToCompany);
로그인 후 복사

출력:

877.85 = 1586.6 - 708.75
로그인 후 복사

위 내용은 Java에서 Double을 계산할 때 반올림 오류를 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿