ホームページ >バックエンド開発 >Golang >sync.WaitGroup を使用して Go 同時実行でデッドロックを防ぐ方法は?

sync.WaitGroup を使用して Go 同時実行でデッドロックを防ぐ方法は?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-25 08:53:02303ブラウズ

How to Prevent Deadlock in Go Concurrency with sync.WaitGroup?

ゴルーチンのデッドロックの解決

このシナリオでは、Go 同時実行コードでデッドロック エラーが発生しました。問題を詳しく調べて、効率的な解決策を提供しましょう。

エラーは、プロデューサーとコンシューマーの動作の不一致により発生します。プロデューサー関数に実装されたプロデューサーは、限られた期間、チャネル ch で値を送信します。ただし、メイン関数に存在するコンシューマは無限に実行され、ch.

から値を受信しようと無限に試行します。このデッドロックを解決するには、コンシューマがプロデューサの完了を尊重するようにする必要があります。これは、プロデューサーが値の送信を終了したときにコンシューマーが自動的に終了する必要があることを意味します。

1 つの効果的なアプローチは、sync.WaitGroup を利用してプロデューサーを調整することです。待機グループを使用すると、プロデューサーの進行状況を追跡し、チャンネルを閉じる前にプロデューサーがタスクを完了するのを待つことができます。コードの改良版は次のとおりです。

<code class="go">func main() {
    var wg sync.WaitGroup
    ch := make(chan int)

    wg.Add(1)
    go producer(ch, 100*time.Millisecond, 2, &wg)

    wg.Add(1)
    go producer(ch, 200*time.Millisecond, 5, &wg)

    // Start a goroutine to close the channel when all producers are done
    go func() {
        wg.Wait()
        close(ch)
    }()

    // Use a for range loop to receive values from the channel
    for v := range ch {
        fmt.Println(v)
    }
}</code>

この更新されたコードでは、アクティブなプロデューサーの数を追跡するために sync.WaitGroup が使用されます。プロデューサーは、値の送信が終了したときに wg.Done() を呼び出して待機グループをデクリメントします。メインのゴルーチンは、すべてのプロデューサーが wg.Wait() の使用を完了するのを待ってから、ch チャネルを閉じます。

sync.WaitGroup を利用することで、コンシューマーが完了ステータスを尊重できるようにする調整メカニズムを確立します。プロデューサーの機能を強化し、デッドロック エラーを効果的に解決します。

以上がsync.WaitGroup を使用して Go 同時実行でデッドロックを防ぐ方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。