C# の lock
ステートメント内で await
の使用が禁止されている理由
C# では、await
演算子を lock
ステートメント内で使用できません。これはコンパイラ チームによる意図的な設計上の選択です。この機能の実装は難しくありませんが、デッドロックを引き起こす可能性がある危険な行為であると考えられています。
制限の背後にある理由
lock
ステートメント内で await
の使用を許可すると、await
が制御を解放してからメソッドが再開されるまでの間に任意のコードが実行されます。このコードは、元のロック階層と矛盾する順序でロックを取得し、デッドロックを引き起こす可能性があります。
さらに、await
の実行は、最初にロックを取得したスレッドとは別のスレッドで再開される場合があります。これにより、ロックを取得したスレッドとは別のスレッドでロックが解除される可能性が生じますが、これは非常に望ましくないことです。
カスタム ロックの実装への影響
カスタム ロック実装 (指定されたコード例で提供されているものなど) を使用してこの制限を回避しようとすると、予測不能でデッドロックが発生しやすい動作が発生する可能性があります。これは、await
操作の進行中に別のスレッドがロックを取得すると、ExitDisposable
クラスの Monitor.Exit
呼び出しが無期限にブロックされる可能性があるためです。
結論
await
演算子は強力な非同期プログラミング機能を提供しますが、lock
ステートメント内での await
の使用の禁止など、推奨されるベスト プラクティスに従うことの重要性を理解することが重要です。この制限は、デッドロックを防止し、マルチスレッド コードの安全性と信頼性を確保することを目的としています。
以上がC# の `lock` ステートメント内で `await` を使用できないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。