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 druckt Go Print 9.12 für „912 * 0.01', aber 9.120000000000001 für „float64(912) * 0.01'?

Linda Hamilton
Freigeben: 2024-12-16 15:33:15
Original
414 Leute haben es durchsucht

Why Does Go Print 9.12 for `912 * 0.01` but 9.120000000000001 for `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)
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage