이 글은 주로 PHP에서 발생하는 부정확한 부동 소수점 연산에 대한 해결책을 소개합니다. 관심 있는 친구들이 참고하면 도움이 될 것입니다.
최근에 만드시나요? 덧셈과 뺄셈의 문제는 부동 소수점 연산이 부정확하다는 점입니다. 해석된 언어가 부동 소수점 연산에 문제가 있는 것은 사실인 것 같습니다.
먼저 코드를 살펴보세요:
<?php $a = 0.1; $b = 0.7; var_dump(($a + $b) == 0.8);
인쇄된 값은 실제로 부울 false입니다.
PHP 매뉴얼에는 부동 소수점 숫자에 대해 다음과 같은 경고 메시지가 있습니다.
경고
부동 소수점 정밀도
0.1이나 0.7과 같은 단순한 소수는 약간의 정밀도 손실 없이 내부 이진 형식으로 변환할 수 없습니다. 이로 인해 혼란스러운 결과가 발생할 수 있습니다. 예를 들어, 바닥((0.1+0.7)*10)은 일반적으로 예상되는 8 대신 7을 반환합니다. 왜냐하면 결과의 내부 표현은 7.9999999999... 와 같기 때문입니다.
이것은 유한한 자릿수로 특정 소수를 정확하게 표현하는 것이 불가능하다는 사실과 관련이 있습니다. 예를 들어, 10진수 1/3은 0.3333333이 됩니다.
그러므로 부동 소수점 숫자 결과가 마지막 자리까지 정확하다고 절대 믿지 말고 두 부동 소수점 숫자가 같은지 비교하지 마세요. 정말로 더 높은 정밀도가 필요하다면 임의의 정밀도 수학 함수나 gmp 함수를 사용해야 합니다
그런 다음 위의 계산을
위 내용은 이 기사의 전체 내용이므로 모든 사람의 학습에 도움이 되기를 바랍니다.
관련 권장 사항:
위 내용은 PHP에서 부정확한 부동 소수점 연산에 대한 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!