컴퓨터 프로그래밍에서 우리는 항상 부동 소수점 연산의 정밀도 문제에 직면하게 됩니다. 이 기사는 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 '<br />'; 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!