Queue<T>.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 的物件。 在 Queue<T> 的預設實作中,這個屬性一律會傳回目前的執行個體。

實作

備註

中的 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) 運算。

適用於

另請參閱