Maison >interface Web >js tutoriel >Pourquoi l'arithmétique à virgule flottante de JavaScript produit-elle des résultats inattendus et comment puis-je résoudre ce problème ?
Pièges et solutions de précision en virgule flottante en JavaScript
L'arithmétique en virgule flottante de JavaScript peut parfois conduire à des résultats inattendus. Considérez ce code :
function test() { var x = 0.1 * 0.2; document.write(x); } test();
Au lieu du 0,02 attendu, il imprime 0,020000000000000004. Cet écart provient d'inexactitudes inhérentes à la représentation des nombres décimaux sous forme de valeurs binaires à virgule flottante.
Solutions élégantes
Pour résoudre ce problème sans recourir aux fonctions d'arrondi, vous ont plusieurs options :
Considérations pratiques
Bien que la première option offre le plus de précision, elle peut être excessivement précise pour la plupart des cas d'utilisation. Dans de tels cas, envisagez simplement de formater votre résultat avec un nombre fixe de décimales lors de son affichage.
Il est crucial de comprendre que les limitations de précision en virgule flottante ne sont pas spécifiques à JavaScript ; ils s'appliquent à tous les langages de programmation qui utilisent l'arithmétique binaire à virgule flottante. La clé réside dans le choix de la solution appropriée en fonction des exigences de précision de votre application.
En résumé, aborder la précision en virgule flottante en JavaScript implique d'examiner attentivement la précision nécessaire et de sélectionner l'approche la plus adaptée à votre cas d'utilisation spécifique. .
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!