Lorsque le code est en cours d'exécution, parfois le temps passé dans la fonction Attack() est imprimé Je sais que lorsqu'une attaque écrit sur un canal et que le principal la lit, puis que le principal sort et n'attend pas que le minuteur ("attaque") s'exécute, ce sont des conditions de course
Je suis nouveau ici :_)
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 }
Quelqu'un peut-il me dire comment gérer cette situation, je souhaite imprimer le temps pris par les deux fonctions et utiliser les canaux
quand main
退出时,程序将终止,并发 goroutine 不会正常终止(在许多程序中,非主 goroutine 是辅助“守护进程”,根本不会关闭),因此不能保证现有的 defer 会运行。这就是这里发生的情况:当您发送烟雾信号时,如果 attack
goroutine 被取消调度,那么 main 可以在重新调度之前返回,因此 defer
ne fonctionne jamais.
Il existe de nombreuses options pour gérer cela, mais elles conduisent toutes fondamentalement au même résultat : assurez-vous d'envoyer sur la chaîne après l'exécution de la fonction , vous pouvez le faire via par exemple (non exhaustif)
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!