Sorted コレクション型
System.Collections.SortedList クラス、System.Collections.Generic.SortedList<TKey, TValue> ジェネリック クラス、および System.Collections.Generic.SortedDictionary<TKey, TValue> ジェネリック クラスは、IDictionary インターフェイスを実装する点において Hashtable クラスと Dictionary<TKey, TValue> ジェネリック クラスに似ていますが、キーによる並べ替え順序で自身の要素を維持し、ハッシュ テーブルの O(1) 挿入と取得の特性はありません。 この 3 つのクラスには、次のような共通の特徴があります。
3 つのすべてのクラスは、System.Collections.IDictionary インターフェイスを実装します。 2 つのジェネリック クラスは、System.Collections.Generic.IDictionary<TKey, TValue> ジェネリック インターフェイスも実装します。
各要素は、列挙で使用できるようにキーと値の組み合わせになっています。
メモ SortedList 非ジェネリック クラスは列挙されると DictionaryEntry オブジェクトを返しますが、2 つのジェネリック型のクラスは KeyValuePair<TKey, TValue> オブジェクトを返します。
要素は System.Collections.IComparer の実装 (非ジェネリック クラスの SortedList) または System.Collections.Generic.IComparer<T> 実装 (2 つのジェネリック クラス) に基づいて並べ替えられます。
各クラスは、キーのみまたは値のみを含むコレクションを返すプロパティを提供します。
次の表に、2 つの並べ替えリスト クラスと SortedDictionary<TKey, TValue> クラスの違いを示します。
SortedList 非ジェネリック クラスと SortedList<TKey, TValue> ジェネリック クラス |
SortedDictionary<TKey, TValue> ジェネリック クラス |
---|---|
キーと値を返すプロパティにはインデックスが付けられるため、インデックスを使用して効率的に取得できます。 |
インデックスを使用して取得することはできません。 |
取得は O(log n) です。 |
取得は O(log n) です。 |
挿入と削除は一般に O(n) ですが、既に並べ替えられているデータの挿入は O(1) のため、各要素はリストの最後に追加されます。 これは、サイズを変更する必要がないことを前提にしています。 |
挿入と削除は O(log n) です。 |
SortedDictionary<TKey, TValue> より使用するメモリが少なくなります。 |
SortedList 非ジェネリック クラスと SortedList<TKey, TValue> ジェネリック クラスより多くのメモリを使用します。 |
複数のスレッドから同時にアクセスできる必要がある並べ替えリストまたは辞書の場合、ConcurrentDictionary<TKey, TValue> から派生するクラスに並べ替えロジックを追加できます。
メモ |
---|
対応するキーを含む値 (従業員 ID 番号を含む従業員レコードなど) に対しては、KeyedCollection<TKey, TItem> ジェネリック クラスから派生することによってリストの特性と辞書の特性を合わせ持つキー付きのコレクションを作成できます。 |
.NET Framework Version 4 以降では、SortedSet<T> クラスは、データを挿入、削除、および検索した後にデータの並べ替え順序を保持する自動調整ツリーを提供します。 このクラスおよび HashSet<T> クラスは、ISet<T> インターフェイスを実装します。
参照
参照
System.Collections.IDictionary
System.Collections.Generic.IDictionary<TKey, TValue>
ConcurrentDictionary<TKey, TValue>