Methode zur Steuerung der Ausführungsreihenfolge von Goroutinen und Kanälen in Golang

WBOY
Freigeben: 2023-08-09 09:06:24
Original
1402 Leute haben es durchsucht

Golang 中 Goroutines 和 Channels 的执行顺序控制方法

Methode zur Steuerung der Ausführungssequenz von Goroutinen und Kanälen in Golang

In der Golang-Programmierung sind Goroutine und Kanal zwei sehr wichtige Konzepte. Goroutine ist ein leichter Thread, der während der Ausführung eines Programms mehrere Funktionen gleichzeitig ausführen kann. Channel ist ein Mechanismus zur Kommunikation zwischen Goroutinen.

In einigen Fällen müssen wir die Ausführungsreihenfolge von Goroutine und Channel steuern, um sicherzustellen, dass das Programm wie erwartet ausgeführt wird. In diesem Artikel werden einige gängige Methoden zur Implementierung der Sequenzsteuerung von Goroutine und Channel vorgestellt.

Methode 1: WaitGroup verwenden

WaitGroup ist ein Zähler, der verwendet wird, um auf das Ende einer Gruppe von Goroutinen zu warten. Sein Funktionsprinzip besteht darin, dass der Zähler bei jedem Start einer Goroutine um eins erhöht wird; nach jeder Ausführung einer Goroutine wird der Zähler um eins dekrementiert. Wenn der Zähler Null erreicht, setzt der Hauptthread die Ausführung fort.

Das Folgende ist ein Beispielcode, der WaitGroup zur Sequenzsteuerung verwendet:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup

    wg.Add(2)

    go func() {
        defer wg.Done()
        fmt.Println("Goroutine 1")
    }()

    go func() {
        defer wg.Done()
        fmt.Println("Goroutine 2")
    }()

    wg.Wait()

    fmt.Println("Main Goroutine")
}
Nach dem Login kopieren

In diesem Beispiel erstellen wir zwei Goroutinen, jede Goroutine gibt eine Nachricht aus. In jeder Goroutine übergeben wir defer wg.Done() 语句将计数器减一。最后,wg.Wait(), um den Hauptthread zu blockieren, bis alle Goroutinen ausgeführt sind.

Führen Sie den obigen Code aus. Die Ausgabe lautet:

Goroutine 1
Goroutine 2
Main Goroutine
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Es ist ersichtlich, dass die Ausführungsreihenfolge von Goroutine 1 und Goroutine 2 ungewiss ist, sie jedoch abgeschlossen sein müssen, bevor der Hauptthread „Main Goroutine“ ausgibt.

Methode 2: Verwenden Sie einen ungepufferten Kanal

Ein ungepufferter Kanal kann verwendet werden, um die Ausführung einer Goroutine zu blockieren, bis eine andere Goroutine Daten vom Kanal empfängt. Durch den Aufbau einer Goroutine-Abhängigkeitskette können wir mehrere Goroutinen nacheinander ausführen.

Das Folgende ist ein Beispielcode für die sequentielle Steuerung mithilfe eines ungepufferten Kanals:

package main

import (
    "fmt"
)

func main() {
    ch1 := make(chan struct{})
    ch2 := make(chan struct{})

    go func() {
        fmt.Println("Goroutine 1")
        ch1 <- struct{}{}
    }()

    go func() {
        <-ch1
        fmt.Println("Goroutine 2")
        ch2 <- struct{}{}
    }()

    <-ch2

    fmt.Println("Main Goroutine")
}
Nach dem Login kopieren

In diesem Beispiel sendet Goroutine 1, nachdem es eine Nachricht gedruckt hat, eine leere Struktur an den Kanal ch1. Als nächstes druckt Goroutine 2 eine weitere Nachricht, nachdem es die Daten vom Kanal ch1 empfangen hat, und sendet eine leere Struktur an den Kanal ch2. Schließlich gibt der Hauptthread „Main Goroutine“ aus, nachdem er Daten vom ch2-Kanal empfangen hat.

Führen Sie den obigen Code aus. Die Ausgabe lautet:

Goroutine 1
Goroutine 2
Main Goroutine
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Sie können sehen, dass die Ausführungsreihenfolge von Goroutine 1 und Goroutine 2 festgelegt ist und abgeschlossen werden muss, bevor der Hauptthread „Main Goroutine“ ausgibt.

Methode 3: Verwenden Sie einen gepufferten Kanal

Ein gepufferter Kanal ermöglicht es uns, beim Erstellen eine Kapazität anzugeben, die eine bestimmte Datenmenge speichern kann. Durch entsprechendes Festlegen der Puffergröße können wir die Anzahl der gleichzeitigen Ausführungen von Goroutine steuern und eine Sequenzkontrolle erreichen.

Das Folgende ist ein Beispielcode für die sequentielle Steuerung mithilfe eines gepufferten Kanals:

package main

import (
    "fmt"
)

func main() {
    ch := make(chan struct{}, 2)

    go func() {
        fmt.Println("Goroutine 1")
        ch <- struct{}{}
    }()

    go func() {
        fmt.Println("Goroutine 2")
        ch <- struct{}{}
    }()

    <-ch
    <-ch

    fmt.Println("Main Goroutine")
}
Nach dem Login kopieren

In diesem Beispiel erstellen wir einen Kanal mit einem Puffer der Kapazität 2. In jeder Goroutine senden wir eine leere Struktur an den ch-Kanal. Schließlich gibt der Hauptthread „Main Goroutine“ aus, nachdem er zweimal Daten vom ch-Kanal empfangen hat.

Führen Sie den obigen Code aus. Die Ausgabe lautet:

Goroutine 1
Goroutine 2
Main Goroutine
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Sie können sehen, dass die Ausführungsreihenfolge von Goroutine 1 und Goroutine 2 festgelegt ist und abgeschlossen werden muss, bevor der Hauptthread „Main Goroutine“ ausgibt.

Durch die obige Methode können wir die Ausführungsreihenfolge von Goroutine und Channel flexibel steuern. Je nach tatsächlichem Bedarf kann die Auswahl der geeigneten Methode die Parallelität und Effizienz des Programms verbessern.

Zusammenfassung:

In diesem Artikel werden drei gängige Methoden zur Steuerung der Ausführungsreihenfolge von Goroutine und Channel in Golang vorgestellt: Verwendung von WaitGroup, Verwendung von ungepuffertem Kanal und Verwendung von gepuffertem Kanal. Durch den rationalen Einsatz dieser Methoden kann eine flexible Parallelitätskontrolle erreicht und die Leistung und Effizienz des Programms verbessert werden.

Das obige ist der detaillierte Inhalt vonMethode zur Steuerung der Ausführungsreihenfolge von Goroutinen und Kanälen in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage