>  기사  >  백엔드 개발  >  PHP의 부정확한 부동 소수점 계산 해결 사례 공유

PHP의 부정확한 부동 소수점 계산 해결 사례 공유

*文
*文원래의
2017-12-25 11:05:472067검색

컴퓨터 프로그래밍에서 우리는 항상 부동 소수점 연산의 정밀도 문제에 직면하게 됩니다. 이 기사는 PHP의 부정확한 부동 소수점 연산을 해결하는 예를 공유합니다. 이 글이 부동 소수점 연산의 정밀도 문제를 해결하는 데 도움이 되기를 바랍니다. 포인트 운영.

부동소수점 계산 결과 비교

부동소수점 계산의 예는 다음과 같습니다.

$a = 0.2+0.7;
$b = 0.9;
var_dump($a == $b);

인쇄된 결과는 bool(false)입니다. 즉, 여기서 0.2+0.7의 계산 결과는 0.9와 같지 않으며 이는 분명히 우리의 상식에 어긋납니다.

이 문제와 관련하여 공식 PHP 매뉴얼에는 다음과 같이 명시되어 있습니다. 분명히 0.2와 같은 간단한 소수는 약간의 정밀도를 잃지 않고 내부 이진 형식으로 변환할 수 없습니다. 이는 특정 소수를 유한한 자릿수로 정확하게 표현하는 것이 불가능하다는 사실과 관련이 있습니다. 예를 들어, 10진수 1/3은 0.3333333...이 됩니다.

위 변수를 배정밀도 형식으로 인쇄합니다.

$a = 0.2+0.7;
$b = 0.9;
printf("%0.20f", $a);
echo &#39;<br />&#39;;
printf("%0.20f", $b);


출력 결과는 다음과 같습니다.

0.89999999999999991118
0.90000000000000002220

분명히 여기서는 부동 소수점 데이터로서 정확도의 일부가 손실되어 도달할 수 없습니다. 완전히 정확합니다. 따라서 부동 소수점 숫자 결과가 마지막 숫자까지 정확하다고 절대 신뢰하지 말고 두 개의 부동 소수점 숫자가 같은지 비교하지 마십시오. 이는 PHP의 문제가 아니라 컴퓨터 내부 부동 소수점 숫자 처리의 문제라는 점에 유의해야 합니다! C, JAVA 등의 언어에서도 동일한 문제가 발생합니다.

두 개의 부동 소수점 숫자를 비교하려면 비교하기 전에 필요한 정밀도 범위 내에서 제어해야 하므로 bcadd() 함수를 사용하여 부동 소수점 숫자를 추가하고 정밀도를 문자열로 변환합니다.

var_dump(bcadd(0.2,0.7,1) == 0.9); // 输出:bool(true)

부동 소수점 수 반올림

"PHP 반올림 함수 천정 및 바닥" 기사에 다음 예가 있습니다.

<?php
echo ceil(2.1/0.7);    // 输出:4
?>

위의 부동 소수점 수 계산에 대한 논의를 마친 후, 우리는 이것이 부동 소수점 수의 불완전한 정확도로 인해 발생한다는 것을 알고 있습니다. 계산 결과:


<?php
printf("%0.20f", (2.1/0.7));    // 输出:3.00000000000000044409
?>


위의 부동 소수점 계산에 대한 논의를 마친 후, 이는 부정확한 부동 소수점 계산 결과로 인해 발생한다는 것을 알았으므로 round() 함수를 사용하여 이를 처리할 수 있습니다. :

<?php
echo ceil( round((2.1/0.7),1) );
?>

round() 함수는 지정된 정밀도에 따라 반올림되지만 소수점 한 자리를 유지해도 반올림 결과에 영향을 미치지 않습니다.

관련 권장 사항:

php 부동 소수점 수 반올림 방법

PHP 부동 소수점 수 정밀도 정보

php 부동 소수점 수 반올림 함수_PHP 튜토리얼

위 내용은 PHP의 부정확한 부동 소수점 계산 해결 사례 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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