>Java >java지도 시간 >Java에서 부동 소수점 숫자를 비교하기 위해 `==`를 사용하는 것이 왜 문제가 됩니까?

Java에서 부동 소수점 숫자를 비교하기 위해 `==`를 사용하는 것이 왜 문제가 됩니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-24 20:41:10458검색

Why Is Using `==` to Compare Floating-Point Numbers in Java Problematic?

부동 소수점 값 비교: Java의 동등성의 함정

==이 부동 소수점 값의 동등 연산자로 사용된다는 Java 문서에도 불구하고 포인트 번호를 비교에 활용하면 우려가 발생할 수 있습니다. 예시에 표시된 대로:

if(sectionID == currentSectionID)

정적 분석을 호출하면 "JAVA0078 부동 소수점 값이 =="와 비교됨 오류가 발생합니다. 그 이유는 이진 부동 소수점 표현의 본질적인 한계에 있습니다.

부동 소수점 값을 ==와 비교하는 것은 사과를 오렌지와 비교하는 것과 비슷합니다. 이러한 값은 정확한 표현이 아닌 근사치이므로 동일한 값이라도 다른 이진 표현이 생성될 수 있습니다. 결과적으로 ==는 기본 부동 소수점 값이 아닌 변수 메모리 주소의 내용을 확인합니다.

올바른 접근 방식

이 문제를 해결하려면 권장되는 접근 방식은 허용 오차 임계값을 기준으로 부동 소수점 값을 비교하는 것입니다. '동등성' 테스트는 다음과 같습니다.

if(Math.abs(sectionID - currentSectionID) < epsilon)

여기서 엡실론은 원하는 정밀도 수준에 맞춰 조정된 0.00000001과 같은 작은 숫자를 나타냅니다. 이 방법은 두 부동 소수점 값 간의 절대 차이가 임계값 엡실론보다 작은지 여부를 평가합니다. 그렇다면 지정된 허용오차 내에서 '동일'한 것으로 간주됩니다.

결론

== 연산자는 부동 소수점 값을 비교하는 간단한 방법을 제공하지만, 단점이 있으므로 주의가 필요합니다. 부정확성과 신뢰할 수 없는 비교를 방지하기 위해 앞서 언급한 공차 기반 접근 방식을 활용하여 부동 소수점 비교의 정확성과 신뢰성을 보장하는 것이 좋습니다.

위 내용은 Java에서 부동 소수점 숫자를 비교하기 위해 `==`를 사용하는 것이 왜 문제가 됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.