.NET での cancelTokenSource の破棄を理解する
CancellationTokenSource
クラスは、.NET アプリケーションでキャンセルを管理するために重要です。 しかし、その適切な処分はしばしば見落とされ、潜在的な資源漏洩につながります。 この記事では、CancellationTokenSource
オブジェクトを効果的に破棄するタイミングと方法を明確にします。
廃棄が重要な理由
CancellationTokenSource
はアンマネージド リソース (具体的には KernelEvent) に依存します。 正しく破棄しないと、これらのリソースが解放されずに残り、メモリ リークが発生します。これは、長時間実行されるプロセスまたはサービスで特に問題になります。
効果的な廃棄方法
最適な廃棄戦略は、アプリケーションのコンテキストによって異なります。
ステートメントの使用 (同期タスクまたはすぐに待機可能なタスクの場合): キャンセルタスクが同期的に完了する場合、またはその完了を簡単に待機できる場合は、CancellationTokenSource
ステートメント内に using
をカプセル化します。これにより、タスク完了時の廃棄が保証されます。
ContinueWith Task (非同期タスクの場合): 即時破棄できない非同期操作の場合は、ContinueWith
タスクをキャンセル タスクにアタッチします。この継続タスクは、CancellationTokenSource
.
明示的な破棄 (PLINQ などのシナリオの場合): 固有の同期メカニズム (PLINQ クエリなど) が欠如している場合は、操作が完了したら CancellationTokenSource
を手動で破棄します。
CancelTokenSource の使い捨ての性質
CancellationTokenSource
インスタンスは単一使用向けに設計されていることを覚えておくことが重要です。 キャンセル後のリセットや再利用はできません。 キャンセルリクエストごとに新しいインスタンスを作成することは、予測可能な動作とリソース管理のために不可欠です。
ベストプラクティス
リソースのリークを防ぎ、アプリケーションの安定性を維持するために、CancellationTokenSource
オブジェクトが不要になったら常に速やかに破棄してください。 タスクの性質 (同期、非同期、その他) に基づいて、適切な破棄手法を採用します。 キャンセル操作ごとに常に新しい CancellationTokenSource
を作成します。
以上がCancelTokenSource をいつ、どのように破棄する必要がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。