ホームページ > バックエンド開発 > Golang > この golang の例では、ミューテックス部分に含まれる条件がデッドロックにならないのはなぜですか?

この golang の例では、ミューテックス部分に含まれる条件がデッドロックにならないのはなぜですか?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2024-02-13 18:06:10
転載
920 人が閲覧しました

为什么在这个 golang 示例中,互斥体部分中包含的条件不会出现死锁?

この golang の例で、ミューテックス部分に含まれる条件でデッドロックが発生しないのは、ミューテックスが `Lock()` と `Unlock() ` を経由しているためです。共有リソースへの相互排他的アクセスを実現する方法。 goroutine が `Lock()` メソッドを呼び出すときに、ミューテックスが別の goroutine によってすでにロックされている場合、mutex が解放されるまで goroutine はブロックされます。このブロック メカニズムにより、ミューテックスがロックされている場合、複数のゴルーチンが同時に共有リソースにアクセスすることがなくなり、デッドロックの発生が回避されます。したがって、この例では、ミューテックスが正しく使用されているため、条件はデッドロックされません。

質問内容

私はオライリー社の研修中にこの例を見ました。 widgetInventory がマイナスになるのを防ぐ条件があります。この例は機能しますが、makeSales がミューテックスを取得し、widgetInventory が 0 のときにプログラムがデッドロックにならない理由がわかりません。

リーリー

makeSales がミューテックスを取得し、widgetInventory が 0 の場合、コードがデッドロックすることが予想されます。

解決策

条件がミューテックスに関連付けられていることに気づきませんでした。 newPurchase =sync.NewCond(&mutex) .Wait() を入力すると、ミューテックスのロックが解除され、条件信号の受信時にミューテックスの再取得が試行されます。

condition.Wait() はミューテックスを取得する場合にのみ使用できるため、コードが読みにくくなりますが、動作します :-)

以上がこの golang の例では、ミューテックス部分に含まれる条件がデッドロックにならないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:stackoverflow.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート