Maison > Java > javaDidacticiel > Java Integer compareTo() : Pourquoi une comparaison, pas une soustraction ?

Java Integer compareTo() : Pourquoi une comparaison, pas une soustraction ?

Mary-Kate Olsen
Libérer: 2024-12-13 03:35:08
original
953 Les gens l'ont consulté

Java Integer compareTo(): Why Comparison, Not Subtraction?

Java Integer compareTo() : Pourquoi la comparaison au lieu de la soustraction

La méthode compareTo() de la classe Integer de Java est conçue pour comparer deux entiers objets. Fait intéressant, il utilise à cette fin des opérateurs de comparaison au lieu de soustraction. Explorons la raison de ce choix.

Débordement d'entier

Lors de la comparaison de deux entiers, l'utilisation de la soustraction peut entraîner un débordement d'entier, en particulier lorsqu'il s'agit de valeurs grandes ou négatives. En effet, la soustraction implique de soustraire la deuxième valeur de la première, ce qui peut produire un résultat en dehors de la plage d'entiers représentables par le type de données.

Considérez l'exemple suivant :

int thisVal = Integer.MAX_VALUE;
int anotherVal = -1;
int diff = thisVal - anotherVal; // Overflow occurs
Copier après la connexion

Dans ce cas, la valeur de thisVal est la valeur maximale d'un entier (2^31 - 1), et anotherVal est une valeur négative. Soustraire ce dernier du premier produirait un résultat supérieur à 2^31 - 1, provoquant un débordement d'entier et un résultat de comparaison incorrect.

Opérateurs de comparaison

L'utilisation d'opérateurs de comparaison (par exemple, <, >, ==) évite le problème de débordement susmentionné. Ces opérateurs comparent directement les bits des deux valeurs, sans effectuer aucune opération arithmétique. Cela garantit que le résultat ne débordera jamais et représentera avec précision la relation entre les opérandes.

Implémentation

L'implémentation de compareTo() dans la classe Integer en tient compte et utilise la logique suivante :

public int compareTo(Integer anotherInteger) {
    int thisVal = this.value;
    int anotherVal = anotherInteger.value;
    return ( thisVal < anotherVal ? -1 : ( thisVal == anotherVal ? 0 : 1 ) ) ;
}
Copier après la connexion

Cette implémentation utilise l'opérateur conditionnel ternaire (?:) pour déterminer le résultat de la comparaison en fonction des valeurs de thisVal et d'un autreVal. Il garantit que le résultat correct est renvoyé sans provoquer de débordement d'entier.

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