Anomalie de division en virgule flottante : pourquoi (3/5) donne-t-il zéro en double précision ?
Lors de l'exécution d'opérations arithmétiques sur une virgule flottante chiffres, les programmeurs rencontrent souvent des résultats surprenants. Une telle anomalie se produit avec l'opérateur de division (/). Bien que les nombres soient stockés sous forme de valeurs à virgule flottante double précision, une simple division telle que (3/5) peut entraîner la sortie inattendue de zéro.
Ce comportement découle du fait que 3 et 5 sont des nombres entiers. par défaut en C . Lorsque des nombres entiers sont utilisés dans une expression arithmétique, l'opérateur de division effectue une division entière, ce qui élimine la partie fractionnaire du résultat.
Correction de l'opération de division
Pour obtenir le résultat correct de la division en virgule flottante, il faut s'assurer qu'au moins un opérande est une valeur à virgule flottante. Ceci peut être réalisé en convertissant l’un des nombres entiers en un nombre à virgule flottante double précision. Par exemple, on peut utiliser le code suivant :
double f = 3.0 / 5;
Dans ce cas, le 3.0 est un nombre à virgule flottante double précision, garantissant que le compilateur effectue une division en virgule flottante, qui conserve la partie fractionnaire du résultat.
En convertissant l'un des opérandes en une valeur à virgule flottante, l'opérateur de division produit désormais le résultat attendu, qui est 0,6 dans ce cas. Cette technique permet aux programmeurs d'effectuer correctement des opérations arithmétiques sur des nombres à virgule flottante et d'éviter des sorties nulles inattendues.
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!