Heim >Backend-Entwicklung >Golang >Warum ist die Ausgabe meines Go-Programms immer 1, wenn eine gleichzeitige Goroutine eine gemeinsam genutzte Variable erhöht?

Warum ist die Ausgabe meines Go-Programms immer 1, wenn eine gleichzeitige Goroutine eine gemeinsam genutzte Variable erhöht?

Susan Sarandon
Susan SarandonOriginal
2024-10-31 01:36:29663Durchsuche

Why is the output of my Go program always 1 when a concurrent goroutine is incrementing a shared variable?

Liegt das daran, dass der Go-Compiler den Code optimiert hat?

Im bereitgestellten Go-Code wird die Variable i zwischen der Haupt-Goroutine und geteilt eine gleichzeitige Goroutine, die mit go func() { ... }() erstellt wurde. Der Zweck der gleichzeitigen Goroutine besteht darin, i auf unbestimmte Zeit zu erhöhen. Beim Ausführen des Programms ist Ihnen jedoch aufgefallen, dass die Ausgabe immer 1 ist, obwohl Sie eine viel größere Zahl erwartet haben, da die gleichzeitige Goroutine genügend Zeit hat, i um ein Vielfaches zu erhöhen.

Um dieses Verhalten zu verstehen, müssen wir Folgendes tun Berücksichtigen Sie das Go-Memory-Modell und die Optimierungen des Compilers.

Go-Memory-Modell

Das Go-Memory-Modell gibt die Bedingungen an, unter denen Lesevorgänge einer Variablen in einer Goroutine garantiert werden können um Werte zu beobachten, die durch Schreibvorgänge in dieselbe Variable in einer anderen Goroutine erzeugt werden.

Laut dem Go-Speichermodell müssen Änderungen an gemeinsam genutzten Variablen, damit sie in allen Goroutinen sichtbar sind, von einem Synchronisierungsereignis gefolgt werden, z eine Kanaloperation oder das Sperren eines Mutex.

Compiler-Optimierungen

In Ihrem Beispiel folgt auf die Zuweisung zu i innerhalb der gleichzeitigen Goroutine kein Synchronisationsereignis. Daher kann nicht garantiert werden, dass die Zuweisung von der Haupt-Goroutine eingehalten wird, und es steht dem Compiler frei, den Code nach eigenem Ermessen zu optimieren.

Der aggressive Compiler optimiert möglicherweise den Code, indem er die Inkrementierungsoperation vollständig eliminiert , wodurch die gleichzeitige Goroutine effektiv auf eine Endlosschleife reduziert wird, die nichts tut. Diese Optimierung würde erklären, warum die Ausgabe immer 1 ist, da die Haupt-Goroutine niemals die von der gleichzeitigen Goroutine durchgeführten Inkremente beobachtet.

Um sicherzustellen, dass Aktualisierungen gemeinsamer Variablen korrekt über Goroutinen hinweg weitergegeben werden, ist es wichtig, den Zugriff zu synchronisieren auf diese Variablen mithilfe von Kanälen, Mutexes oder anderen Synchronisierungsprimitiven, die von Gos Sync- und Sync/Atomic-Paketen bereitgestellt werden.

Das obige ist der detaillierte Inhalt vonWarum ist die Ausgabe meines Go-Programms immer 1, wenn eine gleichzeitige Goroutine eine gemeinsam genutzte Variable erhöht?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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