> Java > java지도 시간 > Java에서 부동 소수점 정밀도 오류를 방지하는 방법: Floats, Doubles 및 BigDecimal

Java에서 부동 소수점 정밀도 오류를 방지하는 방법: Floats, Doubles 및 BigDecimal

Susan Sarandon
풀어 주다: 2024-11-18 04:43:02
원래의
873명이 탐색했습니다.

How to Avoid Floating Point Precision Errors in Java: Floats, Doubles, and BigDecimal

Java에서 부동 소수점 및 Double의 부동 소수점 정밀도 오류 방지

Java에서 많은 양의 부동 소수점 또는 Double을 사용하여 작업할 때 부동 소수점이 누적됩니다. 정밀도 오류가 문제가 될 수 있습니다. 이 오류는 float 또는 double이 0.1과 같은 특정 숫자 값을 정확하게 나타낼 수 없기 때문에 발생합니다.

다음 코드를 고려하세요.

for (float value = 0.0f; value < 1.0f; value += 0.1f) {
    System.out.println(value);
}
로그인 후 복사

예상 출력:

0.1
0.2
0.3
...
0.9
로그인 후 복사
로그인 후 복사

실제 출력:

0.0
0.1
0.2
0.3
0.4
0.5
0.6
0.70000005
0.8000001
0.9000001
로그인 후 복사

분명히 출력은 부동 소수점 부정확성으로 인해 예상 값에서 벗어납니다. 이 문제를 해결하려면 다음 두 가지 기본 접근 방식이 있습니다.

1. 표시 정밀도 조정 및 공차 허용

이중 유형을 사용할 때 표시를 필요한 자릿수로 제한하고 동일성 검사를 위해 작은 공차를 도입합니다. 이를 통해 큰 반올림 오류 없이 0.1과 같은 숫자를 표현할 수 있습니다.

2. 정확한 표현을 위해 BigDecimal 사용

또는 부동소수점 또는 복식 대신 BigDecimal 사용을 고려해 보세요. BigDecimal은 임의의 정밀도로 숫자를 표현하는 방법을 제공하여 반올림 오류를 제거하고 0.1과 같은 값을 정확하게 표현할 수 있습니다.

다음은 BigDecimal을 활용하는 예입니다.

BigDecimal step = new BigDecimal("0.1");
for (BigDecimal value = BigDecimal.ZERO;
     value.compareTo(BigDecimal.ONE) < 0;
     value = value.add(step)) {
    System.out.println(value);
}
로그인 후 복사

이 코드는 인쇄됩니다. :

0.1
0.2
0.3
...
0.9
로그인 후 복사
로그인 후 복사

적절한 접근 방식을 선택하면 개발자는 부동 소수점 작업 시 부동 소수점 정밀도 오류를 효과적으로 최소화하거나 제거할 수 있습니다. 또는 Java에서는 두 배입니다.

위 내용은 Java에서 부동 소수점 정밀도 오류를 방지하는 방법: Floats, Doubles 및 BigDecimal의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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