Compilerfehler für Nulldivision in Go-Gleitkommaoperationen
Beim Versuch, eine Division durch Null mithilfe von float64-Variablen in Go durchzuführen, der Compiler löst einen Fehler aus, anstatt eine Warnung auszugeben. Dieses Verhalten mag kontraintuitiv erscheinen, da man erwarten könnte, dass eine Warnung in solchen Situationen angemessener ist.
Betrachten Sie die folgenden Beispiele:
<code class="go">func main() { var y float64 = 0.0 var x float64 = 4.0 / y fmt.Println(x) }</code>
Dieses Codefragment führt zur Ausgabe Inf, was darauf hinweist dass das Ergebnis positiv unendlich ist.
Wenn wir jedoch den Code so ändern, dass er explizit durch 0,0 dividiert, gibt der Compiler einen Fehler aus:
<code class="go">func main() { var x float64 = 4.0 / 0.0 fmt.Println(x) }</code>
Die Fehlermeldung lautet: prog.go: 9:22: Division durch Null.
Verstehen des Verhaltens
Die numerischen Golang-Konstanten, einschließlich Gleitkommakonstanten, haben besondere Eigenschaften und werden nicht direkt dem IEEE754-Float zugeordnet Typen. Im Gegensatz zu diesen Typen können Go-Konstanten keine Unendlichkeit oder negative Null darstellen.
Laut der Go-Dokumentation:
„Numerische Konstanten stellen exakte Werte beliebiger Genauigkeit dar und überlaufen nicht. Folglich gibt es keine.“ Konstanten, die die negativen IEEE-754-Werte Null, Unendlich und Nicht-Zahl-Werte bezeichnen Wenn Sie einen Unendlichkeitswert benötigen, können Sie die Funktion math.Inf verwenden:
Das obige ist der detaillierte Inhalt vonWarum gibt der Go-Compiler einen Fehler für die Nulldivision bei Gleitkommaoperationen aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!