Maison >Java >javaDidacticiel >Pourquoi ne devriez-vous pas utiliser == pour comparer les flotteurs en Java ?
Question : Pièges liés à l'utilisation de == pour la comparaison des nombres flottants en Java
Malgré sa présence en tant qu'opérateur d'égalité pour les nombres à virgule flottante en Java , == a des limites lors de la comparaison des flottants, comme en témoignent les avertissements d'analyse statique tels que "JAVA0078 Valeurs à virgule flottante comparées à ==".
Réponse : le problème de précision
Les nombres à virgule flottante sont stockés sous forme d'approximations et des erreurs d'arrondi peuvent survenir pendant les opérations. Par conséquent, utiliser == pour comparer deux flottants peut donner des faux négatifs ou positifs.
L'approche correcte : marge de tolérance
L'approche appropriée pour comparer les flottants pour « l'égalité » implique de tester si la différence absolue entre eux est inférieure à une valeur de tolérance prédéfinie. Cela garantit que la comparaison tient compte des erreurs d'arrondi et correspond à la précision souhaitée :
if(Math.abs(sectionID - currentSectionID) < epsilon)
Sélection de la valeur Epsilon
La sélection d'une valeur epsilon appropriée dépend de la précision souhaitée. Pour des comparaisons précises, des valeurs epsilon plus petites sont utilisées, tandis que des valeurs epsilon plus grandes permettent des marges d'erreur plus larges.
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!