PropertyCollection.System.Collections.ICollection.SyncRoot プロパティ
アセンブリ: System.DirectoryServices (system.directoryservices.dll 内)

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

基になっているストアがパブリックではないコレクションの場合、現在のインスタンスを返す実装が要求されます。ただし、他のコレクションをラップするコレクションの場合、現在のインスタンスへのポインタを返すだけでは不十分なことがあります。このようなコレクションは、基になっているコレクションの SyncRoot プロパティを返す必要があります。
System.Collections 名前空間内のほとんどのコレクション クラスは、Synchronized メソッドも実装しています。このメソッドは、基になるコレクションをラップする同期されたラッパーを提供します。ただし、派生クラスでは、SyncRoot プロパティを使用して、独自にコレクションを同期させることができます。コードによる同期操作は、コレクションで直接実行するのではなく、コレクションの SyncRoot で実行する必要があります。これにより、他のオブジェクトから派生したコレクションの操作が正常に実行されます。特に、コレクション インスタンスを同時に変更する可能性がある別スレッドとの間で、正常な同期を維持します。
コレクションが Synchronized メソッドを実装していない場合は、SyncRoot を次のように使用します。
ICollection MyCollection =... lock(MyCollection.SyncRoot) { // Some operation on the collection, which is now thread safe. }
Dim myCollection as New ICollection() SyncLock myCollection.SyncRoot ' Some operation on the collection, which is now thread safe. End SyncLock
コレクションの列挙処理は、本質的にはスレッド セーフな処理ではありません。コレクションが同期されている場合でも、他のスレッドがそのコレクションを変更する可能性はあり、そのような状況が発生すると列挙子は例外をスローします。列挙処理を確実にスレッド セーフに行うには、列挙中にコレクションをロックするか、他のスレッドによって行われた変更によってスローされる例外をキャッチします。

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 によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


Weblioに収録されているすべての辞書からPropertyCollection.System.Collections.ICollection.SyncRoot プロパティを検索する場合は、下記のリンクをクリックしてください。

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