共用方式為


Dictionary<TKey,TValue>.ICollection.SyncRoot 屬性

定義

取得可用以同步存取 ICollection 的物件。

property System::Object ^ System::Collections::ICollection::SyncRoot { System::Object ^ get(); };
object System.Collections.ICollection.SyncRoot { get; }
member this.System.Collections.ICollection.SyncRoot : obj
 ReadOnly Property SyncRoot As Object Implements ICollection.SyncRoot

屬性值

可用來同步存取 ICollection 的物件。

實作

備註

System.Collections.Generic 命名空間中集合的預設實作未同步處理。

透過集合進行列舉在本質上並非安全執行緒程序。 若要確保列舉期間的執行緒安全性,您可以在整個列舉期間鎖定集合。 若要讓多重執行緒能夠存取集合以便進行讀取和寫入,您必須實作自己的同步處理。

屬性 SyncRoot 會傳回物件,這個物件可用來同步存取 ICollection。 只有在存取集合之前,所有線程都會鎖定物件時,同步處理才會生效。 下列程式代碼顯示 C#、C++ 和 Visual Basic 的 屬性用法 SyncRoot

ICollection ic = ...;
lock (ic.SyncRoot) {
   // Access the collection.
}
Dim ic As ICollection = ...
SyncLock ic.SyncRoot
   ' Access the collection.
End SyncLock
ICollection^ ic = ...;
try {
   Monitor::Enter(ic->SyncRoot);
   // Access the collection.
}
finally {
   Monitor::Exit(ic->SyncRoot);
}

取得此屬性的值是 O (1) 作業。

適用於

另請參閱