Maison  >  Article  >  développement back-end  >  Conditions de course à pied

Conditions de course à pied

王林
王林avant
2024-02-08 21:00:041178parcourir

Conditions de course à pied

Contenu de la question

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


Réponse correcte


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)

  • Différer l'envoi du message avant le timer (différer l'exécution dans l'ordre inverse)
  • defer() en sous-fonction, signal en fonction externe
  • N'utilisez pas le report, exécutez simplement le message de sortie avant d'envoyer le signal
  • Au lieu d'envoyer le message et de l'imprimer séparément, envoyez le temps d'exécution de la fonction via le canal et laissez l'appelant le formater et le signaler

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer