Heim >Backend-Entwicklung >Golang >Warum druckt Go Print 9.12 für „912 * 0.01', aber 9.120000000000001 für „float64(912) * 0.01'?
Warum die Diskrepanz zwischen zwei float64s?
Bedenken Sie die folgenden Go-Schnipsel:
fmt.Println(912 * 0.01) fmt.Println(float64(912) * 0.01)
Solange Sie es richtig verstanden haben Dass die zweite Zeile 9.120000000000001 ausgibt, fragen Sie sich vielleicht warum die erste Zeile 9.12 ohne das nachgestellte ...01 ausgibt.
Die Antwort liegt in Gos Umgang mit konstanten Ausdrücken, wie in der Spezifikation definiert:
Konstante Ausdrücke werden immer genau ausgewertet; Zwischenwerte und die Konstanten selbst erfordern möglicherweise eine deutlich höhere Genauigkeit als von jedem vordeklarierten Typ in der Sprache unterstützt.
Da 912 * 0,01 ein konstanter Ausdruck ist, wird er mit äußerster Präzision ausgewertet. Die gleiche Genauigkeit wird beibehalten, wenn das Ergebnis dieses Ausdrucks als Argument an fmt.Println() übergeben wird. Im Wesentlichen verhält sich fmt.Println(912 * 0.01) so, als wäre es fmt.Println(9.12), wobei 9.12 eine exakte Darstellung des ausgewerteten Ausdrucks ist.
Im Gegensatz dazu, wenn Sie 912 explizit in float64 umwandeln In der zweiten Zeile werden beide Operanden der Gleitkommamultiplikation implizit auf float64 gecastet. Da 0,01 in float64 nicht präzise dargestellt werden kann, kommt es zu einem Präzisionsverlust, der zum Vorhandensein von ...01 in der Ausgabe führt.
Der Unterschied in den Ergebnissen resultiert also aus der Präzision, die bei der Auswertung konstanter Ausdrücke beibehalten wird, und der impliziten Casting beteiligt an float64(912) * 0,01.
Das obige ist der detaillierte Inhalt vonWarum druckt Go Print 9.12 für „912 * 0.01', aber 9.120000000000001 für „float64(912) * 0.01'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!