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 중국어 웹사이트의 기타 관련 기사를 참조하세요!