Why does the go routine behave like this?
php editor Xigua will answer your question about "the reason for the go routine behavior". The routine (goroutine) in the Go language is a lightweight concurrency mechanism that can achieve the effect of concurrent execution. However, in some cases, the behavior of go routines may have some unexpected results. This is mainly due to the scheduling mechanism of go routines and the characteristics of the memory model. Before we deeply understand the routine behavior of the Go language, we need to understand these features and their impact on program behavior.
Question content
I am reading a book called "Go in action" and I am a little confused about the goroutine part of the book. Basically I want to know two things about the following code thing:
package main import ( "fmt" "runtime" "sync" "time" ) var counter int = 0 var wg sync.WaitGroup var mtx sync.Mutex func main() { wg.Add(2) runtime.GOMAXPROCS(1) go incCounter("A") go incCounter("B") wg.Wait() fmt.Println(counter) } func incCounter(prefix string) { fmt.Println("Started thread ", prefix) defer wg.Done() mtx.Lock() { fmt.Println("Incrementing counter from ", prefix) counter = counter + 1 fmt.Println("Passing to another thread") runtime.Gosched() for i := 1; i < 100; i++ { time.Sleep(1 * time.Second) fmt.Println("Thread still executing ", prefix) } } mtx.Unlock() }
The output is:
Started thread B Incrementing counter from B Passing to another thread Started thread A Thread still executing B Thread still executing B Thread still executing B Thread still executing B
- Why does it execute goroutine B first? Because in the code goroutine A comes first, I want it to run first as well.
- Goroutine B uses the .Gosched method to let goroutine A start executing, but since the mutex is locked, goroutine A will wait for it to be unlocked. At this time, I set GOMAXPROCS to have only one logical processor. Why does it seem that the two goroutines are running in parallel? Should this really happen?
As I said, setting gomaxprox to 1 will allow only one Goroutine to be executed at a time, but in this case, that doesn't seem to be the case, in fact both Goroutines are running in parallel.
Solution
Goroutines run concurrently. This means that if there are processors available, the scheduler can schedule them to run in parallel. If only one processor is available, they will still run concurrently, but only one goroutine will be running at any given moment.
The Go runtime makes no guarantees about which goroutine will run first. So the running order of a group of newly created goroutines is random,
The above is the detailed content of Why does the go routine behave like this?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Which libraries in Go are developed by large companies or well-known open source projects? When programming in Go, developers often encounter some common needs, ...

Queue threading problem in Go crawler Colly explores the problem of using the Colly crawler library in Go language, developers often encounter problems with threads and request queues. �...

The difference between string printing in Go language: The difference in the effect of using Println and string() functions is in Go...

The library used for floating-point number operation in Go language introduces how to ensure the accuracy is...

Regarding the problem of custom structure tags in Goland When using Goland for Go language development, you often encounter some configuration problems. One of them is...

Two ways to define structures in Go language: the difference between var and type keywords. When defining structures, Go language often sees two different ways of writing: First...

Go pointer syntax and addressing problems in the use of viper library When programming in Go language, it is crucial to understand the syntax and usage of pointers, especially in...

The problem of using RedisStream to implement message queues in Go language is using Go language and Redis...
