Heim >Backend-Entwicklung >Golang >Rennbedingungen laufen

Rennbedingungen laufen

王林
王林nach vorne
2024-02-08 21:00:041237Durchsuche

Rennbedingungen laufen

Frageninhalt

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
}

Kann mir jemand sagen, wie ich mit dieser Situation umgehen soll? Ich möchte die von beiden Funktionen benötigte Zeit ausdrucken und Kanäle nutzen.


Richtige Antwort


wenn

nie läuft. main 退出时,程序将终止,并发 goroutine 不会正常终止(在许多程序中,非主 goroutine 是辅助“守护进程”,根本不会关闭),因此不能保证现有的 defer 会运行。这就是这里发生的情况:当您发送烟雾信号时,如果 attack goroutine 被取消调度,那么 main 可以在重新调度之前返回,因此 defer

Es gibt viele Möglichkeiten, damit umzugehen, aber alle führen im Grunde zum gleichen Ergebnis: Stellen Sie sicher, dass Sie den Kanal weiterleiten, nachdem die Funktion ausgeführt wurde

, Sie können dies beispielsweise über tun (nicht erschöpfend)

    Verschieben Sie das Senden der Nachricht vor dem Timer (verschieben Sie die Ausführung in umgekehrter Reihenfolge)
  • defer() in Unterfunktion, Signal in externer Funktion
  • Verwenden Sie keine Verzögerung, sondern führen Sie einfach die Exit-Nachricht aus, bevor Sie das Signal senden
  • Anstatt die Nachricht separat zu senden und zu drucken, senden Sie die Laufzeit der Funktion über den Kanal und lassen Sie den Anrufer sie formatieren und melden

Das obige ist der detaillierte Inhalt vonRennbedingungen laufen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen