>백엔드 개발 >PHP 튜토리얼 >PHP 부동 소수점 숫자가 부정확한 이유는 무엇이며 어떻게 해결할 수 있습니까?

PHP 부동 소수점 숫자가 부정확한 이유는 무엇이며 어떻게 해결할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-31 14:09:151051검색

Why Are PHP Floating-Point Numbers Inaccurate, and How Can I Fix It?

PHP 부동 소수점 정밀도: 예상치 못한 문제 풀기

PHP에서 부동 소수점 숫자는 이진수 고유의 특성으로 인해 예상치 못한 결과를 낳을 수 있습니다. 산수. 실수와 달리 이진 부동 소수점은 정밀도가 제한되어 근사치 및 부정확성이 발생할 수 있습니다.

예제를 고려하세요.

$a = '35';
$b = '-34.99';
echo ($a + $b);

이렇게 하면 예상되는 0.01 대신 0.009999999999998이 출력됩니다. 34.99와 0.01은 이진수로 정확하게 표현할 수 없어 대략적으로 표현되기 때문입니다.

이 문제를 극복하려면 다음 대안을 고려하세요.

  • 결과 반올림 : 결과를 ​​소수점 이하 두 자리로 반올림하려면 round($result, 2)를 사용하세요. place.
  • 정수 사용: 통화 계산의 경우 값을 정수로 저장합니다. 예를 들어 $35.00를 3500으로, $34.99를 3499로 표현하고 계산 후 결과를 100으로 나눕니다.

PHP에는 다른 언어에서 발견되는 전용 십진수 데이터 유형이 부족하므로 잠재적으로 개선될 수 있습니다. 특정 시나리오의 정확성. 그러나 개발자는 부동 소수점 연산의 한계를 이해함으로써 예상치 못한 결과를 완화하고 정확한 계산을 보장할 수 있습니다.

위 내용은 PHP 부동 소수점 숫자가 부정확한 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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