Wenn der Code ausgeführt wird, wird manchmal die in der Funktion attack() verbrachte Zeit gedruckt Ich weiß, dass es sich um Rennbedingungen handelt, wenn ein Angriff in einen Kanal schreibt und der Hauptkanal ihn liest und der Hauptkanal dann beendet wird und nicht auf die Ausführung des Timers („Angriff“) wartet
Ich bin neu hier :_)
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 }
nie läuft. main
退出时,程序将终止,并发 goroutine 不会正常终止(在许多程序中,非主 goroutine 是辅助“守护进程”,根本不会关闭),因此不能保证现有的 defer 会运行。这就是这里发生的情况:当您发送烟雾信号时,如果 attack
goroutine 被取消调度,那么 main 可以在重新调度之前返回,因此 defer
, Sie können dies beispielsweise über tun (nicht erschöpfend)
Das obige ist der detaillierte Inhalt vonRennbedingungen laufen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!