Maison >Java >javaDidacticiel >Pourquoi la multiplication en Java produit-elle des résultats inattendus lorsqu'il s'agit de grands nombres ?
Comprendre les résultats de multiplication et les types de données en Java
En Java, le résultat d'une opération de multiplication dépend des types de données des opérandes. Cela est particulièrement évident lors de la multiplication de grandes valeurs, comme illustré par l'exemple de code suivant :
long oneYearWithL = 1000 * 60 * 60 * 24 * 365L; long oneYearWithoutL = 1000 * 60 * 60 * 24 * 365; System.out.println(oneYearWithL); // Output: 31536000000 System.out.println(oneYearWithoutL); // Output: 1471228928
Explication :
Comprendre le dépassement d'entier :
En Java, les entiers sont des valeurs signées de 32 bits, allant de -2 147 483 648 à 2 147 483 647. Lorsque le résultat d'une opération arithmétique dépasse ces limites, il revient du côté opposé de la plage, provoquant un débordement d'entier.
Dans notre exemple, le résultat de la multiplication de 1000 60 60 24 365 vaut 2 592 000 000. Étant donné que cette valeur dépasse la valeur entière maximale, elle revient à -1 702 967 297, ce que nous voyons comme résultat (1 471 228 928).
Conversion en type de données long :
Pour éviter un débordement d'entier, il est toujours conseillé d'utiliser le type de données long pour les calculs numériques volumineux. En spécifiant explicitement « L » après un nombre, nous pouvons forcer Java à traiter la valeur comme un entier long, garantissant ainsi que le résultat est stocké dans la variable longue de 64 bits.
Bonnes pratiques :
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!