Je veux gérer le cas particulier où la multiplication de deux nombres ensemble provoque un débordement. Le code ressemble à ceci:
int a = 20;
long b = 30;
// if a or b are big enough, this result will silently overflow
long c = a * b;
C'est une version simplifiée. Dans le programme réel a
et b
proviennent ailleurs au moment de l'exécution. Ce que je veux réaliser est quelque chose comme ceci:
long c;
if (a * b will overflow) {
c = Long.MAX_VALUE;
} else {
c = a * b;
}
Comment me suggérez-vous de coder au mieux cela?
Mise à jour: a
et b
sont toujours non négatifs dans mon scénario.