HybridDictionary.IsSynchronized プロパティ
HybridDictionary が同期されている (スレッド セーフである) かどうかを示す値を取得します。
名前空間: System.Collections.Specialized
アセンブリ: System (system.dll 内)
構文
'宣言
Public ReadOnly Property IsSynchronized As Boolean
'使用
Dim instance As HybridDictionary
Dim value As Boolean
value = instance.IsSynchronized
public bool IsSynchronized { get; }
public:
virtual property bool IsSynchronized {
bool get () sealed;
}
/** @property */
public final boolean get_IsSynchronized ()
public final function get IsSynchronized () : boolean
プロパティ値
このプロパティは常に false を返します。
解説
System.Collections.ICollection インターフェイスが IsSynchronized プロパティを必要とするため、HybridDictionary はこのプロパティを実装します。
派生クラスでは、SyncRoot プロパティを使用して、HybridDictionary を同期させることができます。
コレクションの列挙処理は、本質的にはスレッド セーフな処理ではありません。コレクションが同期されている場合でも、他のスレッドがそのコレクションを変更する可能性はあり、そのような状況が発生すると列挙子は例外をスローします。列挙処理を確実にスレッド セーフに行うには、列挙中にコレクションをロックするか、他のスレッドによって行われた変更によってスローされる例外をキャッチします。
使用例
列挙処理中に SyncRoot を使用してコレクションをロックする方法を次のコード例に示します。
HybridDictionary myCollection = new HybridDictionary();
lock(myCollection.SyncRoot) {
foreach (Object item in myCollection) {
// Insert your code here.
}
}
Dim myCollection As New HybridDictionary()
Dim item As Object
SyncLock myCollection.SyncRoot
For Each item In myCollection
' Insert your code here.
Next item
End SyncLock
このプロパティ値を取得することは、O(1) 操作になります。
プラットフォーム
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
参照
関連項目
HybridDictionary クラス
HybridDictionary メンバ
System.Collections.Specialized 名前空間
SyncRoot