首頁  >  文章  >  後端開發  >  Go中如何使用WaitGroups和Mutexes來實現並發goroutine之間的互斥?

Go中如何使用WaitGroups和Mutexes來實現並發goroutine之間的互斥?

Barbara Streisand
Barbara Streisand原創
2024-11-03 22:02:03356瀏覽

How can WaitGroups and Mutexes be used to achieve mutual exclusion between concurrent goroutines in Go?

使用WaitGroup 和互斥體實現並發Goroutines 的互斥

Go 中一次只有一個Goroutine 的情況下實現並發互的斥可以執行某些程式碼,我們可以利用WaitGroup 和互斥體的組合。

WaitGroup 是一個同步原語,它允許我們等待一組 goroutine 完成執行後再繼續。另一方面,互斥鎖提供了互斥鎖機制,確保程式碼的關鍵部分不會同時被多個 goroutine 執行。

考慮以下範例程式碼:

<code class="go">package main

import (
    "fmt"
    "rand"
    "sync"
)

var (
    mutex1, mutex2, mutex3 sync.Mutex
    wg sync.WaitGroup
)

func Routine1() {
    mutex1.Lock()
    defer mutex1.Unlock() // Ensure mutex is always unlocked before returning
    // do something

    // Sending and printing events should be mutually exclusive
    for i := 0; i < 200; i++ {
        mutex2.Lock()
        defer mutex2.Unlock()
        mutex3.Lock()
        defer mutex3.Unlock()
        fmt.Println("value of z")
    }

    // do something
}

func Routine2() {
    mutex2.Lock()
    defer mutex2.Unlock()
    // do something

    // Sending and printing events should be mutually exclusive
    for i := 0; i < 200; i++ {
        mutex1.Lock()
        defer mutex1.Unlock()
        mutex3.Lock()
        defer mutex3.Unlock()
        fmt.Println("value of z")
    }

    // do something
}

func Routine3() {
    mutex3.Lock()
    defer mutex3.Unlock()
    // do something

    // Sending and printing events should be mutually exclusive
    for i := 0; i < 200; i++ {
        mutex1.Lock()
        defer mutex1.Unlock()
        mutex2.Lock()
        defer mutex2.Unlock()
        fmt.Println("value of z")
    }

    // do something
}

func main() {
    wg.Add(3)
    go Routine1()
    go Routine2()
    Routine3()
    wg.Wait() // Wait for all goroutines to complete
}</code>

在此程式碼中,我們有三個獨立的 goroutine(Routine1、Routine2 和 Routine3),它們都同時執行某些操作。然而,我們希望確保程式碼的某些部分(發送和列印事件)的執行不受其他 goroutine 的干擾。

我們透過利用互斥體來實現這一點。我們定義三個互斥體(互斥體 1、互斥體 2 和互斥體 3),並在執行臨界區之前取得對應互斥體的鎖。當一個互斥鎖被一個 goroutine 鎖定時,其他嘗試取得相同鎖的 goroutine 將被阻塞,直到該鎖變得可用。

透過鎖定和解鎖適當的互斥鎖,我們確保只有一個 goroutine 可以執行臨界區在任何給定時間。這可以防止這些程式碼段同時執行,並保持 goroutine 之間的互斥。

最後,我們使用 WaitGroup 來確保 main 函數在所有三個 goroutine 完成執行之前不會退出。這使我們能夠同步 goroutine 並控製程式的流程。

以上是Go中如何使用WaitGroups和Mutexes來實現並發goroutine之間的互斥?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn