Heim  >  Artikel  >  Backend-Entwicklung  >  Problem mit der PHP-Gleitkommaberechnung

Problem mit der PHP-Gleitkommaberechnung

巴扎黑
巴扎黑Original
2016-11-22 11:06:581579Durchsuche

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


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn