Heim  >  Artikel  >  Backend-Entwicklung  >  Die Eltern-Kind-Beziehung zwischen Golang-Funktionen und Goroutine

Die Eltern-Kind-Beziehung zwischen Golang-Funktionen und Goroutine

WBOY
WBOYOriginal
2024-04-25 12:57:02349Durchsuche

In Go besteht eine Eltern-Kind-Beziehung zwischen Funktionen und Goroutinen. Die übergeordnete Goroutine erstellt die untergeordnete Goroutine, und die untergeordnete Goroutine kann auf die Variablen der übergeordneten Goroutine zugreifen, jedoch nicht umgekehrt. Erstellen Sie eine untergeordnete Goroutine mit dem Schlüsselwort go. Die untergeordnete Goroutine wird über eine anonyme Funktion oder eine benannte Funktion ausgeführt. Eine übergeordnete Goroutine kann über sync.WaitGroup auf den Abschluss untergeordneter Goroutinen warten, um sicherzustellen, dass das Programm nicht beendet wird, bevor alle untergeordneten Goroutinen abgeschlossen sind.

Die Eltern-Kind-Beziehung zwischen Golang-Funktionen und Goroutine

Die Eltern-Kind-Beziehung zwischen Go-Sprachfunktionen und Goroutine

In der Go-Sprache ist Goroutine eine Funktion, die gleichzeitig ausgeführt wird. Goroutinen sind in einer Eltern-Kind-Beziehung organisiert, wobei die übergeordnete Goroutine untergeordnete Goroutinen erstellt. Die untergeordnete Goroutine hat Zugriff auf die Variablen der übergeordneten Goroutine, die übergeordnete Goroutine kann jedoch nicht auf die Variablen der untergeordneten Goroutine zugreifen.

Erstellen Sie eine untergeordnete Goroutine.

Erstellen Sie eine untergeordnete Goroutine mit dem Schlüsselwort go: go 关键字创建一个子 goroutine:

go func() {
  // 子 goroutine 代码
}

子 goroutine 执行匿名函数。同样,我们可以将命名的函数传递给 go 关键字:

func child() {
  // 子 goroutine 代码
}

go child()

访问父 goroutine 变量

子 goroutine 可以访问父 goroutine 的局部变量,而无需显式传递。这是因为 goroutine 在同一内存空间中执行。例如:

func parent() {
  count := 10
  go func() {
    fmt.Println(count) // 输出 10
  }()
}

子 goroutine 可以安全地访问和修改父 goroutine 的变量。但是,由于并发,必须使用锁或其他同步机制来防止数据竞争。

父 goroutine 等待子 goroutine

父 goroutine 可以使用 sync.WaitGroup 等待子 goroutine 完成。WaitGroup 跟踪剩余子 goroutine 的数量,并提供 AddWait 方法:

func parent() {
  var wg sync.WaitGroup
  wg.Add(1)
  go func() {
    defer wg.Done()
    // 子 goroutine 代码
  }()

  wg.Wait() // 等待子 goroutine 完成
}

实战案例:文件下载器

考虑一个并行文件下载器,从多个远程 URL 下载文件。我们可以使用 goroutines 来并发下载,如下所示:

func main() {
  var wg sync.WaitGroup

  urls := []string{"url1", "url2", "url3"}

  for _, url := range urls {
    wg.Add(1)
    go func(url string) {
      defer wg.Done()
      downloadFile(url)
    }(url)
  }

  wg.Wait() // 等待所有文件下载完成
}

在这个案例中,主 goroutine 创建子 goroutine 来下载每个文件。主 goroutine 使用 WaitGrouprrreee

Eine untergeordnete Goroutine führt eine anonyme Funktion aus. Ebenso können wir benannte Funktionen an das Schlüsselwort go übergeben:

rrreee

Zugriff auf übergeordnete Goroutine-Variablen

Untergeordnete Goroutine kann ohne explizite Übergabe auf lokale Variablen der übergeordneten Goroutine zugreifen. Dies liegt daran, dass die Goroutine im selben Speicherbereich ausgeführt wird. Zum Beispiel: 🎜rrreee🎜Eine untergeordnete Goroutine kann sicher auf die Variablen der übergeordneten Goroutine zugreifen und diese ändern. Aufgrund der Parallelität müssen jedoch Sperren oder andere Synchronisationsmechanismen verwendet werden, um Datenwettläufe zu verhindern. 🎜🎜Die übergeordnete Goroutine wartet auf die untergeordnete Goroutine.🎜🎜Die übergeordnete Goroutine kann mit sync.WaitGroup auf den Abschluss der untergeordneten Goroutine warten. WaitGroup verfolgt die Anzahl der verbleibenden untergeordneten Goroutinen und stellt die Methoden Add und Wait bereit: 🎜rrreee🎜Praktischer Fall: Datei-Downloader🎜🎜Betrachten Sie eine parallele Datei Downloader, laden Sie Dateien von mehreren Remote-URLs herunter. Wir können Goroutinen für gleichzeitige Downloads verwenden, wie unten gezeigt: 🎜rrreee🎜 In diesem Fall erstellt die Haupt-Goroutine untergeordnete Goroutinen, um jede Datei herunterzuladen. Die Haupt-Goroutine verwendet WaitGroup, um auf den Abschluss aller untergeordneten Goroutinen zu warten und sicherzustellen, dass das Programm nicht beendet wird, bevor alle Dateien heruntergeladen wurden. 🎜🎜Fazit🎜🎜Das Verständnis der Eltern-Kind-Beziehung zwischen Funktionen und Goroutinen ist entscheidend für die Erstellung robuster paralleler Go-Programme. Durch das Verständnis der Variablenzugriffs- und Goroutine-Synchronisierungsmechanismen können wir leistungsstarke gleichzeitige Anwendungen erstellen. 🎜

Das obige ist der detaillierte Inhalt vonDie Eltern-Kind-Beziehung zwischen Golang-Funktionen und Goroutine. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn