DictionaryBase.System.Collections.ICollection.SyncRoot プロパティ
アセンブリ: mscorlib (mscorlib.dll 内)

Private ReadOnly Property System.Collections.ICollection.SyncRoot As Object Implements ICollection.SyncRoot
private: virtual property Object^ System.Collections.ICollection.SyncRoot { Object^ get () sealed = ICollection::SyncRoot::get; }
DictionaryBase オブジェクトへのアクセスを同期するために使用できるオブジェクト。

派生クラスでは、この SyncRoot プロパティを使用して、独自に DictionaryBase クラスを同期させることができます。コードによる同期操作は、DictionaryBase オブジェクト自体で直接実行するのではなく、DictionaryBase オブジェクトの SyncRoot プロパティで実行する必要があります。これにより、他のオブジェクトから派生したコレクションの操作が正常に実行されます。特に、DictionaryBase オブジェクトを同時に変更する可能性がある別スレッドとの間で、正常な同期を維持します。
コレクションの列挙処理は、本質的にはスレッド セーフな処理ではありません。コレクションが同期されている場合でも、他のスレッドがそのコレクションを変更する可能性はあり、そのような状況が発生すると列挙子は例外をスローします。列挙処理を確実にスレッド セーフに行うには、列挙中にコレクションをロックするか、他のスレッドによって行われた変更によってスローされる例外をキャッチします。

列挙処理中に SyncRoot プロパティを使用してコレクションをロックする方法を次のコード例に示します。
DictionaryBase myCollection = new DictionaryBase(); lock(myCollection.SyncRoot) { foreach (Object item in myCollection) { // Insert your code here. } }

Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


- DictionaryBase.System.Collections.ICollection.SyncRoot プロパティのページへのリンク