Rumah >pembangunan bahagian belakang >Golang >Keadaan perlumbaan larian
Apabila kod berjalan, kadangkala masa yang dihabiskan dalam fungsi attack() dicetak Saya tahu bahawa apabila serangan menulis ke saluran dan saluran utama membacanya dan kemudian keluar utama dan tidak menunggu pemasa ("serangan") untuk dilaksanakan, ia adalah syarat perlumbaan
Saya baru di sini :_)
package main import ( "fmt" "time" ) func timer(funcName string) func(){ startTime := time.Now() return func(){ fmt.Printf("%s took %v time to run \n", funcName, time.Since(startTime)) } } func main(){ defer timer("main")() smokeSignal := make(chan bool) evilNinga := "Tommy" go attack(evilNinga, smokeSignal) fmt.Println(<-smokeSignal) } func attack(target string, smokeSignal chan<-bool){ defer timer("attack")() time.Sleep(time.Second) fmt.Println("Throwing ninja stars at ", target) smokeSignal <- true }
Bolehkah seseorang memberitahu saya bagaimana untuk mengendalikan situasi ini, saya ingin mencetak masa yang diambil oleh kedua-dua fungsi dan menggunakan saluran
apabila main
退出时,程序将终止,并发 goroutine 不会正常终止(在许多程序中,非主 goroutine 是辅助“守护进程”,根本不会关闭),因此不能保证现有的 defer 会运行。这就是这里发生的情况:当您发送烟雾信号时,如果 attack
goroutine 被取消调度,那么 main 可以在重新调度之前返回,因此 defer
tidak pernah berjalan.
Terdapat banyak pilihan untuk menangani perkara ini, tetapi kesemuanya membawa kepada hasil yang sama pada dasarnya: pastikan anda menghantar pada saluran selepas fungsi berjalan , anda boleh melakukan ini melalui contohnya (tidak menyeluruh )
Atas ialah kandungan terperinci Keadaan perlumbaan larian. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!