Maison > Article > développement back-end > Raisons des erreurs de calcul de virgule flottante PHP
Exemple : (Apprentissage recommandé : Tutoriel vidéo PHP)
echo intval(0.58*100);//结果为57 echo intval((0.1 + 0.7) * 10);//结果为7
La raison en est la ordinateur Certains nombres à virgule flottante ne peuvent pas être représentés avec précision en interne en binaire, tout comme nous ne pouvons pas représenter avec précision 10/3 en décimal
La représentation interne des nombres à virgule flottante dans l'ordinateur : IEEE 754. Si vous ne comprenez pas, cherchez vous-même. Pour information
vous pouvez également vous référer à cet article de Bird Brother : http://www.laruence.com/2013/03/26/2884.html
<?php echo intval(0.58*100);//57,注意啦 echo '<br/>'; echo intval(bcmul(0.58, 100));//58 echo '<br/>'; echo floor(strval(0.58*100));//58 echo '<br/>'; echo (int)(0.58 * 1000/10);//58 echo '<br/>'; echo intval((0.1 + 0.7) * 10);//7,注意啦 echo '<br/>'; echo intval(bcadd("0.1", "0.7",1) * 10); //8 ?>
Regardez un autre exemple
<?php if((0.1 + 0.7) == 0.8){ echo '相等'; }else{ echo '不相等'; //这里输出 } echo '<br />'; $a = 0.1 + 0.7; echo $a; //0.8 echo '<br/>'; if($a == 0.8){ echo '一天一小步'; }else{ echo '一年一大步'; //这里输出 } echo '<br/>'; if(strval($a) == 0.8){ echo '一天一小步'; //这里输出 }else{ echo '一年一大步'; } echo '<br/>'; if(bcadd(0.1, 0.7,1) == 0.8){ echo '一天一小步'; //这里输出 }else{ echo '一年一大步'; } /* 结果: 不相等 0.8 一年一大步 一天一小步 一天一小步 */ ?>
$a = 0.00...00(n 0s)1 + 0.7 ; Lorsque vous utilisez strval pour valoriser $a, le nombre de n 0 sera différent, ce qui fait que $a et 0,8 sont égaux. Les résultats sont différents
La fonction bcadd ajoutera deux nombres, en fonction du nombre de décimales que vous choisissez de conserver et supprimera les décimales suivantes
Regardez. un exemple de division :
<?php echo 160500643816367088/10;//1.6050064381637E+16 echo '<br/>'; echo intval(160500643816367088/10);//16050064381636710 echo '<br/>'; echo bcdiv(160500643816367088,10);//16050064381636708 ?>
Donc pour les données sensibles comme les nombres à virgule flottante pour calculer des montants, il est recommandé d'utiliser la fonction BC de PHP
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!