Maison > Article > développement back-end > Comment éviter les inexactitudes dans la multiplication PHP
PHP est un langage open source largement utilisé dans la programmation côté serveur. Ses fonctions puissantes et ses fonctionnalités gratuites en ont fait un outil important dans le développement de sites Web. Cependant, malgré ses excellentes performances et sa fiabilité, PHP présente également certains inconvénients. Parmi eux, le problème de l'imprécision de la multiplication est un problème facilement négligé, mais il peut causer de gros problèmes au processus de développement.
En PHP, la multiplication est un opérateur fréquemment utilisé, qui peut être utilisé pour calculer le produit de deux nombres quelconques. Cependant, en PHP, une imprécision de multiplication se produit lorsque le produit de deux nombres dépasse la valeur maximale du type entier en PHP. Parce qu'en PHP, la valeur maximale du type entier est 2147483647, lorsque le résultat de la multiplication de deux nombres dépasse cette valeur, un résultat incorrect se produira.
Par exemple, le code suivant montre une simple opération de multiplication PHP :
$num1 = 999999999; $num2 = 123456789; $result = $num1 * $num2; echo $result;
Le résultat en cours d'exécution est :
-6101065173502598407
En fait, le résultat correct devrait être : 123456787654321111. En effet, lorsque $num1 est multiplié par $num2, le résultat dépasse la valeur maximale d'un type entier en PHP.
En PHP, étant donné que la plage de nombres pouvant être représentés par le type entier est limitée, lorsque cette plage est dépassée, le résultat sera incorrect. Par conséquent, nous devons être particulièrement prudents lors des opérations de multiplication pour éviter ce problème d’inexactitude. Voici plusieurs façons d'éviter le problème de l'inexactitude des multiplications :
La bibliothèque de fonctions BCMath est un ensemble de fonctions mathématiques de haute précision en PHP qui peuvent être utilisées pour résoudre le problème d'inexactitude des nombres entiers en PHP. Des opérations mathématiques de haute précision peuvent être effectuées avec précision en PHP à l'aide de la bibliothèque de fonctions BCMath.
Convertissez les nombres en chaînes pour les opérations, ce qui peut éviter le problème de l'inexactitude des nombres entiers en PHP. En effet, les opérations sur les chaînes ne sont pas limitées par la plage de nombres.
Par exemple, le code suivant montre un exemple de multiplication à l'aide de chaînes :
$num1 = "999999999"; $num2 = "123456789"; $result = bcmul($num1, $num2); echo $result;
Le résultat en cours d'exécution est :
123456787654321111
Il existe une nouvelle fonction intdiv dans PHP 7, peut être utilisé pour calculer avec précision le quotient entier de deux nombres. En utilisant la fonction intdiv, nous pouvons éviter les problèmes de précision avec la division entière.
Par exemple, le code suivant montre un exemple d'utilisation de la fonction intdiv pour effectuer des opérations de multiplication :
$num1 = 999999999; $num2 = 123456789; $result = intdiv($num1 * $num2, 1); echo $result;
Le résultat en cours d'exécution est :
123456787654321111
En bref, PHP est un langage open source avec des fonctions puissantes, mais lors de l'exécution d'opérations de multiplication , vous devez faire attention à éviter les problèmes d'inexactitude. En utilisant la bibliothèque BCMath, en convertissant des nombres en chaînes pour l'arithmétique ou en utilisant la fonction intdiv de PHP 7, nous pouvons résoudre ce problème et calculer avec précision le produit de deux nombres.
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!