Gleitkommadivision in Go
Trotz der scheinbaren Einfachheit der Division kann die Implementierung dieser Operation in Go zu unerwarteten Ergebnissen führen. Wie im bereitgestellten Beispiel dargestellt:
fmt.Println(3/10)
Dieser Codeausschnitt liefert überraschenderweise „0“ statt der erwarteten „0,3“. Um dieses Verhalten zu verstehen, ist es wichtig, sich mit den Feinheiten des Typsystems von Go zu befassen.
In Go sind die Operanden des Divisionsoperators untypisierte Konstanten, was bedeutet, dass ihr Datentyp nicht explizit angegeben wird. Gemäß der Go-Spezifikation wird bei binären Operationen mit untypisierten Konstanten der Datentyp des Ergebnisses durch die Priorität der beteiligten Typen bestimmt. In diesem Fall sind beide Operanden Ganzzahlen, was zu einem untypisierten Ganzzahlausdruck mit dem Wert „0“ führt.
Um ein Gleitkomma-Konstantenergebnis zu erhalten, muss einer der Operanden explizit als Gleitkomma typisiert werden. Hier einige Beispiele, die dies veranschaulichen:
3.0 / 10.0 3.0 / 10 3 / 10.0
In diesen Ausdrücken sorgt die Gleitkommakonstante (z. B. „3.0“) dafür, dass das Ergebnis auch eine Gleitkommakonstante mit dem Wert „0.3“ ist ".
Wenn alternativ ein Operand eine typisierte Variable ist, hat der Datentyp der typisierten Variablen Vorrang. Die folgenden Ausdrücke konvertieren beispielsweise die Ganzzahlvariablen in float64-Werte und ergeben „0,3“:
var i3 = 3 var i10 = 10 fmt.Println(float64(i3) / 10) fmt.Println(3 / float64(i10))
Das obige ist der detaillierte Inhalt vonWarum führt die Division ganzer Zahlen durch Go zu 0 statt zu einer Gleitkommazahl?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!