Heim >Java >javaLernprogramm >Warum erzeugt die Ganzzahldivision in Java 0,0 anstelle eines Dezimalergebnisses?
Warum ergibt die Ganzzahldivision von Java 0,0?
Bei der Division zweier Ganzzahlen in Java ist das Ergebnis oft nicht das, was Sie vielleicht erwarten würden:
int totalOptCount = 500; int totalRespCount = 1500; float percentage = (float) (totalOptCount / totalRespCount);
In diesem Fall würden Sie einen Prozentsatz von 0,33 (bzw 0,333 gerundet). Sie werden jedoch überrascht sein, dass tatsächlich 0,0 zurückgegeben wird. Warum ist das so?
Konvertierungsbefehl zur Rettung
Der Grund für dieses unerwartete Ergebnis liegt in der Reihenfolge, in der Java seine Berechnungen durchführt. Wenn Sie zwei Ganzzahlen dividieren, wandelt Java diese automatisch in Doppelzahlen um. Diese Konvertierung erfolgt jedoch erst nach der Division. Im obigen Beispiel erfolgt die Berechnung also tatsächlich so:
double percentage = totalOptCount / totalRespCount;
Was einen doppelten Wert von 0,0 ergibt. Um dieses Problem zu beheben, müssen Sie einen der Operanden explizit in einen Float oder Double konvertieren, bevor Sie die Division durchführen:
float percentage = ((float) totalOptCount) / totalRespCount;
Jetzt erfolgt zuerst die Konvertierung in Float und die Division erfolgt auf dem Float Werte, was zum korrekten Float-Wert von 0,333333 führt.
Formatierung für Dezimalzahl Präzision
Sobald Sie das richtige Ergebnis haben, möchten Sie es möglicherweise auf eine bestimmte Dezimalgenauigkeit formatieren. Dazu können Sie die Methode String.format() verwenden:
String str = String.format("%2.02f", percentage);
Dadurch wird die Prozentvariable in eine Zeichenfolge mit zwei Dezimalstellen formatiert, was den Wert 00,33 ergibt.
Das obige ist der detaillierte Inhalt vonWarum erzeugt die Ganzzahldivision in Java 0,0 anstelle eines Dezimalergebnisses?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!