부동 소수점 유형(float, double 또는 real이라고도 합니다. 부동 소수점 숫자의 단어 길이는 플랫폼에 따라 다르지만 일반적으로 최대값은 1.8e308이고 정밀도는 십진수 14자리입니다(64비트 IEEE 형식).
부동 소수점 숫자는 정밀도가 제한되어 있지만 시스템에 따라 PHP는 일반적으로 IEEE 754 배정밀도 형식을 사용하며 반올림으로 인한 최대 상대 오류는 1.11e-16이므로 수행 시 오류 전파를 고려하십시오.
또한 0.1이나 0.7과 같이 십진법으로 정확하게 표현할 수 있는 유리수는 가수가 아무리 많아도 내부적으로 사용되는 이진법으로는 정확하게 표현할 수 없기 때문에 없이는 표현할 수 없습니다. 약간의 손실이 발생합니다.
이렇게 하면 혼란스러운 결과가 발생합니다.
예를 들어 floor((0.1+0.7)*10)
通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999999991118...
이 문서의 예에서는 PHP에서 부동 소수점 숫자의 나머지를 가져오는 방법을 설명합니다.
참고용으로 자세한 내용은 다음과 같습니다. , 나머지 연산을 할 때 가장 먼저 생각하는 것은 퍼센트 기호를 사용하는 것입니다. 그러나 제수가 큰 값이고 int의 범위를 초과하면 나머지가 부정확합니다. php 큰 숫자(부동 소수점 수) ) 나머지 함수:/** * php大数取余 * * @param int or float $bn 除数 * @param int $sn 被除数 * @return int 余数 */ //大数(浮点数)取余方法 function Kmod($bn, $sn) { return intval(fmod(floatval($bn), $sn)); }테스트 코드:
//大数(浮点数)取余方法 function Kmod($bn, $sn) { return intval(fmod(floatval($bn), $sn)); } //整数取余方法 function mod($bn, $sn) { return $bn%$sn; } //最大的int整数 $bn = PHP_INT_MAX; $sn = 11; var_dump($bn); var_dump(Kmod($bn, $sn)); var_dump(mod($bn, $sn)); //给最大的int整数加1 $bn = PHP_INT_MAX + 1; var_dump($bn); var_dump(Kmod($bn, $sn)); var_dump(mod($bn, $sn));실행 결과:
int 2147483647 int 1 int 1 float 2147483648 int 2 int -2
위 내용은 PHP 부동 소수점 수 나머지 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!