Maison > développement back-end > C++ > Pourquoi la comparaison de variables flottantes et doubles pour l'égalité conduit-elle parfois à des résultats inattendus ?

Pourquoi la comparaison de variables flottantes et doubles pour l'égalité conduit-elle parfois à des résultats inattendus ?

Linda Hamilton
Libérer: 2024-11-01 15:39:02
original
314 Les gens l'ont consulté

Why Does Comparing Float and Double Variables for Equality Sometimes Lead to Unexpected Results?

Pourquoi l'égalité des variables Double et Float peut être trompeuse

Les types de données à virgule flottante comme float et double sont essentiels pour représenter des nombres réels dans programmation. Cependant, comprendre leurs nuances est crucial pour éviter des résultats surprenants.

Précision et arrondi : effets malicieux

Les variables flottantes et doubles ont une précision limitée, ce qui signifie qu'elles ne peuvent stocker qu'un nombre fini de chiffres sans perte d'informations. Cette limitation inhérente conduit à des erreurs d'arrondi, où la représentation interne d'un nombre est tronquée pour s'adapter à l'espace disponible.

Un exemple illustratif

Considérez les nombres 1.1 représentés comme flotteur et double. En raison d'une précision limitée, ils sont représentés en interne sous forme d'approximations :

float f = 1.1; // Internally stored as an approximation
double d = 1.1; // Internally stored as an approximation
Copier après la connexion

La comparaison de f et d pour l'égalité renverra false car les erreurs d'arrondi entraînent des représentations internes différentes, même si elles représentent le « même » nombre.

Éviter les ennuis

Pour éviter les comparaisons trompeuses, il est préférable d'éviter en utilisant l'opérateur d'égalité (==) pour les nombres à virgule flottante. Au lieu de cela, introduisez un seuil de tolérance (epsilon) et comparez la différence entre les nombres pour déterminer si elle se situe dans la plage acceptable :

if (abs(f - d) < epsilon) {
  // They are considered equal within the tolerance
}
Copier après la connexion

En comprenant les pièges des comparaisons flottantes et doubles, vous pouvez éviter des résultats inattendus et assurez-vous de l'exactitude de votre code.

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal