Heim > Artikel > Backend-Entwicklung > Die Eltern-Kind-Beziehung zwischen Golang-Funktionen und Goroutine
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.
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 mit dem Schlüsselwort go
: go
关键字创建一个子 goroutine:
go func() { // 子 goroutine 代码 }
子 goroutine 执行匿名函数。同样,我们可以将命名的函数传递给 go
关键字:
func child() { // 子 goroutine 代码 } go child()
子 goroutine 可以访问父 goroutine 的局部变量,而无需显式传递。这是因为 goroutine 在同一内存空间中执行。例如:
func parent() { count := 10 go func() { fmt.Println(count) // 输出 10 }() }
子 goroutine 可以安全地访问和修改父 goroutine 的变量。但是,由于并发,必须使用锁或其他同步机制来防止数据竞争。
父 goroutine 可以使用 sync.WaitGroup
等待子 goroutine 完成。WaitGroup
跟踪剩余子 goroutine 的数量,并提供 Add
和 Wait
方法:
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 使用 WaitGroup
rrreee
go
übergeben: 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!