Integrierte Division: Die Wahrheit hinter 1/3 == 0 enthüllen
Integer-Division in Java kann ein verwirrendes Konzept sein, besonders wenn es so ist handelt es sich um Dezimalwerte. Die Frage ist, warum das Ergebnis von 1 / 3 gleich 0 ist, obwohl wir erwarten, dass es 0,333 ist...
Enthüllung der Arithmetik
In diesem speziellen Fall In diesem Fall sind beide Operanden (1 und 3) Ganzzahlen, was bedeutet, dass standardmäßig Ganzzahlarithmetik verwendet wird. Trotz der Deklaration der Ergebnisvariablen (g) als Double erfolgt nach der Division eine implizite Konvertierung.
Die Feinheiten der Ganzzahldivision
Ganzzahldivision im Gegensatz zur Floating- Punktteilung, rundet das Ergebnis gegen Null. Das wahre Ergebnis der Division, 0,333..., wird folglich auf 0 abgerundet. Der Prozessor behandelt den Dezimalteil im Wesentlichen so, als ob er nicht vorhanden wäre.
Gleitkomma-Arithmetik: Eine andere Geschichte
Wenn beide Operanden als Gleitkommazahlen (3.0 und 1.0) bereitgestellt werden, erfolgt die Gleitkommaarithmetik Vorrang. Daraus ergibt sich der erwartete Bruchwert von 0,333.... Beachten Sie, dass auch dann Gleitkommaarithmetik verwendet wird, wenn nur der erste Operand eine Gleitkommazahl ist (z. B. 3,0 und 1).
Praktisch Lösungen
Um das Dezimalergebnis zu erhalten, ist es notwendig, eine Gleitkommadivision explizit durchzuführen. Dies kann erreicht werden, indem beide Operanden in Doubles oder Floats umgewandelt werden:
public static void main(String[] args) { double g = (double) 1 / 3; // Explicitly cast to double System.out.printf("%.2f", g); }
Alternativ kann man die BigDecimal-Klasse für präzisere numerische Operationen verwenden.
Das obige ist der detaillierte Inhalt vonWarum ist 1/3 gleich 0 in der Java-Ganzzahldivision?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!