백엔드 개발 C++ `float == double`이 항상 작동하지 않는 이유는 무엇입니까?

`float == double`이 항상 작동하지 않는 이유는 무엇입니까?

Nov 01, 2024 am 04:37 AM

Why Doesn't `float == double` Always Work?

Double과 Float의 비교: 왜 예상치 못한 결과가 나오는가?

Double 및 Float와 같은 부동 소수점 숫자는 수치 계산에서 중요한 역할을 합니다. 그러나 이러한 유형을 비교하면 아래 코드 조각에서 볼 수 있듯이 혼란스러운 결과가 나올 수 있습니다.

<code class="python">float f = 1.1
double d = 1.1
if (f == d):  # returns false!</code>
로그인 후 복사

이 예상치 못한 동작은 정밀도와 반올림이라는 두 가지 기본 요소에서 비롯됩니다.

정밀도:

부동 소수점 숫자는 정밀도가 유한하여 정확하게 표현할 수 있는 자릿수를 제한합니다. 정밀도가 높은 숫자에는 더 많은 메모리가 필요하며, 이는 부동 소수점 변수의 경우 항상 가능한 것은 아닙니다.

예를 들어 소수점 이하 자릿수 1/3(0.33333...)은 32비트 형식으로 정확하게 표현할 수 없습니다. 뜨다. 대략적으로 계산하여 0.3333333333333333으로 저장해야 하므로 정밀도가 약간 손실됩니다.

반올림:

이진수와 십진수에는 본질적인 차이가 있습니다. 십진수로 쉽게 표현할 수 있는 분수(예: 1/10을 0.1)는 종종 이진수로 복잡한 표현(예: 1/10을 0.0001100110011...)으로 표현해야 합니다.

이러한 불일치로 인해 반올림 오류가 발생합니다. 부동 소수점 값은 메모리 제한에 맞게 잘립니다. 결과적으로 예제 코드의 0.1 표현은 double에 저장된 0.1과 정확히 동일하지 않을 수 있습니다.

결론:

정밀도 및 반올림 문제로 인해 , 동등(==)을 사용하여 double과 float를 비교하는 것은 신뢰할 수 없습니다. 대신, 보다 강력한 접근 방식은 절대 차이를 허용 가능한 엡실론 값과 비교하는 것입니다. 이렇게 하면 차이가 허용 가능한 허용 범위 내에 있도록 보장됩니다.

<code class="python">if abs(f - d) &lt; epsilon:  # epsilon is a small threshold</code>
로그인 후 복사

이 접근 방식을 사용하면 비교가 정밀도 및 반올림 오류의 영향을 받지 않아 정확하고 일관된 결과를 얻을 수 있습니다.

위 내용은 `float == double`이 항상 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까? C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까? Mar 03, 2025 pm 05:52 PM

C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까?

Gulc : C 도서관은 처음부터 구축되었습니다 Gulc : C 도서관은 처음부터 구축되었습니다 Mar 03, 2025 pm 05:46 PM

Gulc : C 도서관은 처음부터 구축되었습니다

C 언어 함수 형식 문자 케이스 변환 단계 C 언어 함수 형식 문자 케이스 변환 단계 Mar 03, 2025 pm 05:53 PM

C 언어 함수 형식 문자 케이스 변환 단계

C 언어 기능의 정의 및 호출 규칙은 무엇이며 C 언어 기능의 정의 및 호출 규칙은 무엇이며 Mar 03, 2025 pm 05:53 PM

C 언어 기능의 정의 및 호출 규칙은 무엇이며

뚜렷한 사용 및 문구 공유 뚜렷한 사용 및 문구 공유 Mar 03, 2025 pm 05:51 PM

뚜렷한 사용 및 문구 공유

메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까? 메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까? Mar 03, 2025 pm 05:51 PM

메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까?

C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까? C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까? Mar 12, 2025 pm 04:50 PM

C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까?

STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까? STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까? Mar 12, 2025 pm 04:52 PM

STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까?

See all articles