Heim > Backend-Entwicklung > Golang > Golang-Entwicklung: Beherrschung der gleichzeitigen Programmierung basierend auf der Nachrichtenübermittlung

Golang-Entwicklung: Beherrschung der gleichzeitigen Programmierung basierend auf der Nachrichtenübermittlung

WBOY
Freigeben: 2023-09-20 12:49:58
Original
520 Leute haben es durchsucht

Golang-Entwicklung: Beherrschung der gleichzeitigen Programmierung basierend auf der Nachrichtenübermittlung

Golang-Entwicklung: Die Beherrschung der gleichzeitigen Programmierung auf Basis der Nachrichtenübermittlung erfordert spezifische Codebeispiele

Einführung:
Golang bietet als effiziente und prägnante Programmiersprache umfangreiche Funktionen für die gleichzeitige Programmierung, zu denen auch die gleichzeitige Programmierung auf Basis der Nachrichtenübermittlung gehört seine Einzigartigkeit. In diesem Artikel werden wir die gleichzeitige Programmierung auf Message-Passing-Basis in Golang ausführlich besprechen und spezifische Codebeispiele geben, um den Lesern zu helfen, diese Technologie besser zu verstehen und zu beherrschen.

1. Was ist gleichzeitige Programmierung basierend auf der Nachrichtenübermittlung?
Bei der herkömmlichen gleichzeitigen Programmierung nutzen Threads im Programm den gemeinsamen Speicher für die Kommunikation, was leicht zu Problemen wie Deadlocks und Race Conditions führen kann. Die auf Nachrichtenübermittlung basierende gleichzeitige Programmierung verwendet Nachrichten zur Kommunikation zwischen verschiedenen Threads. Die Threads sind relativ unabhängig und vermeiden das Problem des gemeinsam genutzten Speichers.

In Golang basiert die gleichzeitige Programmierung auf Nachrichtenübermittlung hauptsächlich auf Goroutine und Kanal. Eine Goroutine ist ein leichter Thread, der vom Go-Laufzeitplaner verwaltet werden kann. Kanal ist eine Datenstruktur, die zum Übertragen von Nachrichten zwischen Goroutinen verwendet wird.

2. Kanäle für die Nachrichtenweitergabe verwenden
In Golang können durch die Erstellung von Kanalobjekten Nachrichten zwischen verschiedenen Goroutinen weitergeleitet werden. Hier ist ein einfacher Beispielcode, der zeigt, wie Kanäle für die Nachrichtenübermittlung verwendet werden:

func main() {
    // 创建一个int类型的channel
    ch := make(chan int)
    
    // 启动一个goroutine发送消息
    go func() {
        ch <- 1
    }()
    
    // 接收goroutine发送的消息
    num := <-ch
    fmt.Println(num)
}
Nach dem Login kopieren

Im obigen Beispiel wird zunächst ein Kanalobjekt vom Typ int erstellt. Als nächstes verwenden Sie ch <- 1 in einer neuen Goroutine, um eine Nachricht an den Kanal zu senden. Empfangen Sie abschließend die Nachricht vom Kanal über die Anweisung num := <-ch und drucken Sie sie aus. ch。接下来,在一个新的goroutine中使用ch <- 1向channel发送消息。最后,通过num := <-ch语句从channel中接收消息,并将其打印出来。

三、channel的阻塞和非阻塞操作
在使用channel进行消息传递时,有两种基本的操作方式:阻塞和非阻塞。

阻塞操作是指当channel中没有消息可用时,接收操作会一直阻塞,直到有消息可用。同样地,发送操作也会阻塞直到有接收者接收消息。

非阻塞操作是指当channel中没有消息可用时,接收操作会立即返回一个空值。发送操作则会在channel已满时立即返回一个错误。

下面是一个示例代码,展示了如何使用阻塞和非阻塞操作:

func main() {
    ch := make(chan int, 1)
    ch <- 1 // 向channel发送消息
    
    // 阻塞操作
    num := <-ch
    fmt.Println(num)
    
    // 非阻塞操作
    select {
    case num := <-ch:
        fmt.Println(num)
    default:
        fmt.Println("channel中没有消息可用")
    }
}
Nach dem Login kopieren

在上述示例中,首先创建了一个有缓冲区大小为1的channel对象,并向其发送了一个消息。接下来,通过接收操作和非阻塞的选择语句来展示阻塞和非阻塞操作的效果。

四、使用select语句进行多路复用
Golang中的select语句提供了一种方式,可以从多个channel中选择一个可用的channel进行操作。下面是一个示例代码,展示了如何使用select语句进行多路复用:

func main() {
    ch1 := make(chan int)
    ch2 := make(chan int)
    
    go func() {
        ch1 <- 1
    }()
    
    go func() {
        ch2 <- 2
    }()
    
    // 使用select语句选择可用的channel
    select {
    case num := <-ch1:
        fmt.Println(num)
    case num := <-ch2:
        fmt.Println(num)
    }
}
Nach dem Login kopieren

在上述示例中,首先创建了两个不同的channel对象ch1ch2。然后分别向ch1ch2

3. Blockierender und nicht blockierender Betrieb von Kanälen

Bei der Verwendung von Kanälen zur Nachrichtenübertragung gibt es zwei grundlegende Betriebsmethoden: Blockieren und Nichtblockieren.

Blockierungsvorgang bedeutet, dass der Empfangsvorgang blockiert wird, bis eine Nachricht verfügbar ist, wenn im Kanal keine Nachricht verfügbar ist. Ebenso werden Sendevorgänge blockiert, bis ein Empfänger die Nachricht empfängt.

Nicht blockierender Vorgang bedeutet, dass der empfangende Vorgang sofort einen Nullwert zurückgibt, wenn keine Nachricht im Kanal verfügbar ist. Der Sendevorgang gibt sofort einen Fehler zurück, wenn der Kanal voll ist.

Hier ist ein Beispielcode, der zeigt, wie blockierende und nicht blockierende Operationen verwendet werden:
    rrreee
  1. Im obigen Beispiel wird zunächst ein Kanalobjekt mit einer Puffergröße von 1 erstellt und eine Nachricht an dieses gesendet. Als nächstes werden die Auswirkungen blockierender und nicht blockierender Operationen anhand von Empfangsoperationen und nicht blockierenden SELECT-Anweisungen demonstriert.
  2. 4. Verwenden Sie Select-Anweisungen zum Multiplexen.
  3. Die Select-Anweisung in Golang bietet eine Möglichkeit, einen verfügbaren Kanal aus mehreren Kanälen für den Betrieb auszuwählen. Hier ist ein Beispielcode, der zeigt, wie SELECT-Anweisungen zum Multiplexen verwendet werden:
rrreee🎜 Im obigen Beispiel werden zunächst zwei verschiedene Kanalobjekte ch1 und ch2 erstellt. Senden Sie dann Nachrichten an ch1 bzw. ch2. Wählen Sie abschließend die verfügbaren Kanäle mithilfe der Select-Anweisung aus und drucken Sie die entsprechende Meldung aus. 🎜🎜5. Zusammenfassung🎜Dieser Artikel stellt die Konzepte und Funktionen der gleichzeitigen Programmierung basierend auf der Nachrichtenübermittlung in Golang vor und gibt spezifische Codebeispiele. Durch die Verwendung von Goroutine und Channel zur Implementierung der Nachrichtenübermittlung werden relativ unabhängige gleichzeitige Vorgänge zwischen mehreren Goroutinen erreicht. Gleichzeitig werden durch den Einsatz blockierender und nicht blockierender Operationen sowie Select-Anweisungen die Flexibilität und Wartbarkeit der gleichzeitigen Programmierung weiter verbessert. 🎜🎜Ich hoffe, dass die Leser durch die Einführung dieses Artikels die auf Message Passing basierende gleichzeitige Programmierung in Golang besser verstehen und beherrschen, die Vorteile der gleichzeitigen Programmierung in Golang voll ausschöpfen und die Leistung und Zuverlässigkeit des Programms verbessern können. 🎜🎜Referenzmaterialien: 🎜🎜🎜Offizielle Golang-Dokumentation (https://golang.org/doc/) 🎜🎜Üben Sie sich in der gleichzeitigen Programmierpraxis (https://www.imooc.com/learn/927)🎜🎜

Das obige ist der detaillierte Inhalt vonGolang-Entwicklung: Beherrschung der gleichzeitigen Programmierung basierend auf der Nachrichtenübermittlung. 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