Heim > Artikel > Backend-Entwicklung > Problem mit der PHP-Gleitkommaberechnung
Wenn Sie PHPs -*/ verwenden, um Gleitkommazahlen zu berechnen, kann es zu Problemen mit falschen Berechnungsergebnissen kommen. Beispielsweise gibt echo intval(0.58*100); 57 statt 58 aus. Dies ist tatsächlich die zugrunde liegende Binärdatei Ein Fehler
, der Gleitkommazahlen nicht genau darstellen kann, ist auch bei der Verwendung von Python auf dieses Problem gestoßen. Grundsätzlich bieten die meisten Sprachen Klassenbibliotheken oder Funktionsbibliotheken für präzise Berechnungen. PHP verfügt beispielsweise über eine hochpräzise BC-Funktionsbibliothek.
Die hochpräzise Funktionsbibliothek von PHP BC umfasst: Addition, Vergleich, Division, Subtraktion, Rest, Multiplikation, n-te Potenz, Konfiguration der Standardanzahl von Dezimalstellen, Quadrat. Diese Funktionen sind nützlicher, wenn es um monetäre Berechnungen geht, beispielsweise bei der Preisberechnung im E-Commerce.
/**
* Zwei hochpräzise Zahlen vergleichen
*
* @access global
* @param float $left
* @ param float $right
* @param int $scale Anzahl der Dezimalstellen, um genau zu sein
*
* @return int $left==$right Gibt 0 $ zurück left< ;$right gibt -1 zurück |. $left>$right gibt 1 zurück
*/
var_dump(bccomp($left=4.45, $right=5.54, 2));
// -1
/**
* Addiere zwei hochpräzise Zahlen
*
* @access global
* @param float $left
* @ param float $right
* @param int $scale Anzahl der Dezimalstellen, um genau zu sein
*
* @return string
*/
var_dump(bcadd($left=1.0321456, $right=0.0243456, 2));
//1.04
/**
* Subtrahiere zwei hochpräzise Zahlen
*
* @access global
* @param float $left
* @ param float $right
* @param int $scale Anzahl der Dezimalstellen, um genau zu sein
*
* @return string
*/
var_dump(bcsub($left=1.0321456, $right =3.0123456, 2));
//-1.98
/**
* Dividieren Sie zwei hochpräzise Zahlen
*
* @access global
* @param float $left
* @ param float $right
* @param int $scale Anzahl der Dezimalstellen, um genau zu sein
*
* @return string
*/
var_dump(bcdiv($left= 6, $right=5, 2));
//1.20
/**
* Zwei hochpräzise Zahlen multiplizieren
*
* @access global
* @param float $left
* @ param float $right
* @param int $scale Anzahl der Dezimalstellen, um genau zu sein
*
* @return string
*/
var_dump(bcmul( $left=3.1415926, $right=2.4569874566, 2));
//7.71
/**
* Legen Sie die Anzahl der Dezimalstellen für die bc-Funktion fest.
*
* @access global
* @param int $scale Genaue Anzahl der Dezimalstellen Punkte
*
* @return void
*/
bcscale (3);
var_dump(bcdiv('105', '6.55957'));
// 16.007
Hinweis: Über die Einstellungsnummer Bei Ziffern wird der Überschuss verworfen und nicht gerundet