PropertyCollection.ICollection.IsSynchronized 属性

定义

获取一个值,该值指示是否同步对 ICollection 的访问(线程安全)。

property bool System::Collections::ICollection::IsSynchronized { bool get(); };
bool System.Collections.ICollection.IsSynchronized { get; }
member this.System.Collections.ICollection.IsSynchronized : bool
 ReadOnly Property IsSynchronized As Boolean Implements ICollection.IsSynchronized

属性值

Boolean

如果对 true 的访问是同步的(线程安全),则为 ICollection;否则为 false

实现

注解

SyncRoot 返回一个对象,该对象可用于同步对 ICollection 的访问。

命名空间中的 System.Collections 大多数集合类也实现 Synchronized 方法,该方法围绕基础集合提供同步包装器。

通过集合进行枚举本质上不是线程安全过程。 即使某个集合已同步,其他线程仍可以修改该集合,这会导致枚举数引发异常。 若要保证枚举期间的线程安全性,可以在整个枚举期间锁定集合,也可以捕获由其他线程所做的更改导致的异常。

以下示例演示如何使用 SyncRoot 整个枚举期间锁定集合:

ICollection myCollection = new ICollection();  
  lock(myCollection.SyncRoot) {  
  foreach (Object item in myCollection) {  
  // Insert your code here.  
  }  
 }  
Dim myCollection As New ICollection()  
 Dim item As Object  
 SyncLock myCollection.SyncRoot  
  For Each item In myCollection  
  ' Insert your code here.  
  Next item  
 End SyncLock  

适用于

另请参阅