ICollection.IsSynchronized 属性

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

**命名空间:**System.Collections
**程序集:**mscorlib(在 mscorlib.dll 中)

语法

声明
ReadOnly Property IsSynchronized As Boolean
用法
Dim instance As ICollection
Dim value As Boolean

value = instance.IsSynchronized
bool IsSynchronized { get; }
property bool IsSynchronized {
    bool get ();
}
/** @property */
boolean get_IsSynchronized ()
function get IsSynchronized () : boolean

属性值

如果对 ICollection 的访问是同步的(线程安全),则为 true;否则为 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

平台

Windows 98、Windows 2000 SP4、Windows CE、Windows Millennium Edition、Windows Mobile for Pocket PC、Windows Mobile for Smartphone、Windows Server 2003、Windows XP Media Center Edition、Windows XP Professional x64 Edition、Windows XP SP2、Windows XP Starter Edition

.NET Framework 并不是对每个平台的所有版本都提供支持。有关受支持版本的列表,请参见系统要求

版本信息

.NET Framework

受以下版本支持:2.0、1.1、1.0

.NET Compact Framework

受以下版本支持:2.0、1.0

请参见

参考

ICollection 接口
ICollection 成员
System.Collections 命名空间
SyncRoot