Heim >Backend-Entwicklung >Golang >Eine praktische Anleitung zum gleichzeitigen Programmieren von Select Channels Go mit Golang

Eine praktische Anleitung zum gleichzeitigen Programmieren von Select Channels Go mit Golang

PHPz
PHPzOriginal
2023-09-27 21:54:31710Durchsuche

利用golang进行Select Channels Go并发式编程的实践指南

Ein praktischer Leitfaden für Select Channels Go-Parallelitätsprogrammierung mit Golang

Einführung:
In modernen Computeranwendungen wird eine hohe Parallelität immer wichtiger. Um die Leistung des Computers voll auszunutzen, müssen wir gleichzeitige Programmierung verwenden, um Multitasking zu erreichen. Golang ist eine leistungsstarke Programmiersprache, die die gleichzeitige Programmierung unterstützt. Sie bietet einen Mechanismus namens „Kanäle“ zur Implementierung der gleichzeitigen Kommunikation. Durch die Verwendung von Channels- und Select-Anweisungen können wir problemlos gleichzeitige Programmierung implementieren. In diesem Artikel erfahren Sie, wie Sie Channels und Select-Anweisungen in Golang für die gleichzeitige Programmierung verwenden, und stellen spezifische Codebeispiele bereit.

1. Das Grundkonzept von Channels
In Golang ist Channel ein Kommunikationsmechanismus, der zum Übertragen von Daten zwischen Goroutinen (gleichzeitig ausgeführte Funktionen) verwendet wird. Man kann es sich als eine Leitung zwischen Goroutinen vorstellen, durch die Daten fließen. Der Kanal hat zwei wichtige Eigenschaften: Blockierung und Synchronisierung.

  1. Blockierung: Wenn eine Goroutine Daten an einen Kanal sendet und der Kanal voll ist, wird der Sendevorgang blockiert, bis der Kanal wieder eine freie Position hat. Wenn eine Goroutine Daten von einem Kanal empfängt, der Kanal jedoch leer ist, wird der Empfangsvorgang ebenfalls blockiert, bis Daten im Kanal verfügbar sind.
  2. Synchronisation: Der Kanal kann zur Synchronisation zwischen Goroutinen verwendet werden. Wenn eine Goroutine Daten an einen Kanal sendet, wartet sie darauf, dass die empfangende Goroutine die Daten empfängt, bevor sie fortfährt. Wenn eine Goroutine Daten von einem Kanal empfängt, wartet sie auf ähnliche Weise, bis die sendende Goroutine das Senden der Daten abgeschlossen hat, bevor sie fortfährt.

2. Verwenden Sie die Select-Anweisung
In Golang ist die Select-Anweisung ein Mechanismus zur Verarbeitung mehrerer Kanaloperationen. Sie ähnelt einer switch-Anweisung, wird jedoch zur Verarbeitung von Lese- und Schreibvorgängen auf einem Kanal verwendet.

  1. Syntax der Select-Anweisung

    select {
    case channel1 <- data1:
     // 当 channel1 可用时执行
    case data2 := <-channel2:
     // 当 channel2 可用时执行
    case data3, ok := <-channel3:
     // 当 channel3 可用时执行
     // 如果 Channel 被关闭,ok 会被设置为 false,否则为 true
    default:
     // 如果没有任何 Channel 操作可用,则执行 default 语句块
    }
  2. Funktionsprinzip der Select-Anweisung
  3. Wenn mehrere Kanäle verfügbar sind, wählt Select zufällig einen verfügbaren Kanal aus, um entsprechende Vorgänge auszuführen.
  4. Wenn kein Kanal verfügbar ist und kein Standard-Anweisungsblock vorhanden ist, blockiert die Select-Anweisung, bis mindestens ein Kanal verfügbar ist.
  5. Wenn mehrere Kanäle verfügbar sind und kein Standard-Anweisungsblock vorhanden ist, wählt die Select-Anweisung zufällig einen verfügbaren Kanal aus, um entsprechende Vorgänge auszuführen. Wenn mehrere Kanäle verfügbar sind, können wir daher nicht vorhersagen, welcher Kanal ausgewählt wird.

3. Praktischer Leitfaden
Im Folgenden finden Sie einige praktische Richtlinien für die Verwendung von Kanälen und Select-Anweisungen:

  1. Erstellen eines Kanals
    Verwenden Sie die integrierte Make-Funktion, um einen Kanal zu erstellen. Der Beispielcode lautet wie folgt:

    ch := make(chan int)
  2. Senden und Empfangen von Daten
    Verwenden Sie den <- Operator, um Daten an Channel zu senden und zu empfangen. Der Beispielcode lautet wie folgt:

    ch <- data // 发送数据
    data := <-ch // 接收数据
  3. Verwenden Sie die Select-Anweisung für gleichzeitige Vorgänge.
    Verwenden Sie die Select-Anweisung, um mehrere Kanaloperationen abzuwickeln. Der Beispielcode lautet wie folgt:

    select {
    case ch1 <- data1:
     // 当 ch1 可用时执行发送操作
    case data2 := <-ch2:
     // 当 ch2 可用时执行接收操作
    }
  4. Kanal schließen
    Verwenden Sie die integrierte Schließfunktion, um einen Kanal zu schließen. Der Beispielcode lautet wie folgt:

    close(ch)
  5. Simulieren gleichzeitiger Aufgaben
    Goroutinen und Kanäle können verwendet werden, um gleichzeitig ausgeführte Aufgaben zu simulieren. Der Beispielcode lautet wie folgt:

    func worker(id int, jobs <-chan int, results chan<- int) {
     for j := range jobs {
         fmt.Println("Worker", id, "started job", j)
         time.Sleep(time.Second)
         fmt.Println("Worker", id, "finished job", j)
         results <- j * 2
     }
    }
    
    func main() {
     // 创建输入和输出 Channels
     jobs := make(chan int, 100)
     results := make(chan int, 100)
    
     // 创建并发 Goroutines
     for w := 1; w <= 3; w++ {
         go worker(w, jobs, results)
     }
    
     // 发送任务到输入 Channel
     for j := 1; j <= 9; j++ {
         jobs <- j
     }
     close(jobs)
    
     // 输出结果
     for a := 1; a <= 9; a++ {
         <-results
     }
    }

In diesem Artikel wird erläutert, wie Sie Channels- und Select-Anweisungen in Golang für die gleichzeitige Programmierung verwenden. Durch die Verwendung von Channels- und Select-Anweisungen können wir gleichzeitige Aufgaben problemlos implementieren. Ich hoffe, dieser Artikel kann Ihnen helfen, den Mechanismus der gleichzeitigen Programmierung von Golang besser zu verstehen und nützliche Anleitungen für Ihre Projekte bereitzustellen.

Referenzen:

  1. „Concurrency in Go“, The Go Blog, [Online]. Verfügbar: https://blog.golang.org/concurrency-is-not-parallelism.
  2. „Effective Go“, The Go Programmiersprache, [Online]. Verfügbar: https://golang.org/doc/efficient_go.html.

Das obige ist der detaillierte Inhalt vonEine praktische Anleitung zum gleichzeitigen Programmieren von Select Channels Go mit Golang. 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