아니요, PHP에서 부동 소수점 연산에 오류가 있습니다. PHP에서는 부동 소수점 숫자의 정밀도가 제한되어 있습니다. 시스템에 따라 PHP는 일반적으로 IEEE 754 배정밀도 형식을 사용하지만 반올림으로 인한 최대 상대 오류는 "1.11e-16"입니다. 오류가 발생하므로 복합 작업을 수행할 때 오류 전파를 고려해야 합니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, PHP 8 버전, DELL G3 컴퓨터
//加 $a = 0.1; $b = 0.7; $c = intval(($a + $b) * 10); echo $c."<br>"; //输出:7 //减 $a = 100; $b = 99.98; $c = $a - $b; echo $c."<br>"; //输出:0.019999999999996 //乘 $a = 0.58; $b = 100; $c = intval($a * $b); echo $c."<br>"; //输出:57 //除 $a = 0.7; $b = 0.1; $c = intval($a / $b); echo $c."<br>"; //输出:6
위 결과는 분명히 우리가 원하는 것이 아닙니다!
공식 PHP 매뉴얼에서는 다음과 같이 설명합니다.
부동 소수점 숫자는 정밀도가 제한되어 있습니다. 시스템에 따라 다르지만 PHP는 일반적으로 IEEE 754 이중 형식을 사용하므로 반올림으로 인한 최대 상대 오차는 1.11e-16입니다. 기본이 아닌 수학 연산은 더 큰 오류를 초래할 수 있으므로 복합 연산을 수행할 때 오류 전파를 고려해야 합니다. 부동 소수점 결과를 마지막 숫자까지 신뢰하지 말고 두 개의 부동 소수점 숫자가 같은지 비교하지 마십시오. 더 높은 정밀도가 정말로 필요하다면 임의 정밀도 수학 함수 또는 gmp 함수를 사용해야 합니다.
여기서 핵심은 부동 소수점 숫자의 소수가 이진수로 표현된다는 것입니다. 프로세스는 다음과 같습니다.
Decimal 일부 루프가 나타나고 제한된 이진수 비트가 십진수 연산에 오류가 발생하는 이유입니다.
다음으로
임의의 정밀 수학함수를 소개하겠습니다.
임의의 정밀도 수학 함수
공식 매뉴얼:
http://php.net/manual/zh/book.bc.php사용 전 bcmath가 설치되어 있는지 확인해주세요. //加
$a = 0.1;
$b = 0.7;
$c = intval(bcadd($a, $b, 1) * 10);
echo $c."<br>";
//输出:8
//减
$a = 100;
$b = 99.98;
$c = bcsub($a, $b, 2);
echo $c."<br>";
//输出:0.02
//乘
$a = 0.58;
$b = 100;
$c = intval(bcmul($a, $b));
echo $c."<br>";
//输出:58
//除
$a = 0.7;
$b = 0.1;
$c = intval(bcdiv($a, $b));
echo $c."<br>";
//输出:7
덧셈, 뺄셈, 곱셈 및 나눗셈 외에도 bcmath는 다음 방법도 제공합니다.
echo floor(5.1); //输出:5 echo floor(8.8); //输出:8
echo ceil(5.1); //输出:6 echo ceil(8.8); //输出:9
echo round(5.1); //输出:5 echo round(8.8); //输出:9 //保留两位小数并且进行四舍五入 echo round(5.123, 2); //输出:5.12 echo round(8.888, 2); //输出:8.89 //保留两位小数并且不进行四舍五入 echo substr(round(5.12345, 3), 0, -1); //输出:5.12 echo substr(round(8.88888, 3), 0, -1); //输出:8.88
echo round(1.2849, 2, PHP_ROUND_HALF_EVEN); //输出:1.28 echo round(1.2866, 2, PHP_ROUND_HALF_EVEN); //输出:1.29 echo round(1.2851, 2, PHP_ROUND_HALF_EVEN); //输出:1.29 echo round(1.2850, 2, PHP_ROUND_HALF_EVEN); //输出:1.28 echo round(1.2750, 2, PHP_ROUND_HALF_EVEN); //输出:1.28
금액 표시에 적용 우리는 종종 은행 카드 잔액을 봅니다.
echo number_format('10000.98', 2, '.', ','); //输出:10,000.98 echo number_format('340888999', 2, '.', ','); //输出:340,888,999.00
부동소수점 숫자에 오류가 있습니다. 정밀도에 민감한 데이터를 사용할 때는 고정 소수점 숫자(십진수)를 사용하여 저장해야 합니다.
부동소수점수 정밀도 문제를 통해 부동소수점수의 소수가 이진수로 표현된다는 것을 알게 되었습니다.
고정밀 연산을 수행하기 위해 PHP 임의 정밀 수학 함수 사용을 공유했습니다.
또한 반올림, 반올림, 은행원 반올림, 숫자 형식 지정 등과 같은 일반적인 수치 처리 솔루션을 공유했습니다.
마지막으로 PHP의 float를 통해 MySQL의 float를 생각해 봅시다.
앞으로 부동 소수점 계산을 사용할 때는 주의해야 합니다. 세부 사항이 성공 또는 실패를 결정합니다.
추천 학습: "PHP 비디오 튜토리얼"
위 내용은 PHP의 부동 소수점 연산이 정확합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!