誰かがなぜHashTableをループするためにIDictionaryEnumeratorが優先されるのか教えてもらえますか?HashTableのIEnumerator?
これはIEnumeratorとはどのように異なるのですか?
いつ使うのですか?
誰かがなぜHashTableをループするためにIDictionaryEnumeratorが優先されるのか教えてもらえますか?HashTableのIEnumerator?
これはIEnumeratorとはどのように異なるのですか?
いつ使うのですか?
IDictionaryEnumeratorを使用すると、現在のエントリのキーと値の両方にアクセスできます。あなたが注意するように、IDictionaryEnumeratorはIEnumeratorなので、foreachでそれを使用しているのであれば、範囲変数がDictionaryEntryなので、これに気付くだけです。 IDictionaryEnumeratorを手作業で使用している場合は、[Current]と[Key]および[Value]の各プロパティがあることがわかります。
Hashtableをループするには「あまり好きではありません。ハッシュテーブルを列挙すると、値だけでなくキーと値のペアが列挙され、IDictionaryEnumeratorがそのことを表します。
IDictionaryEnumeratorは、キーと値のペアのコレクションを列挙するために特別に設計されています。現在のエントリのキーと値にアクセスすることができます(特に、documentationのように)。 IEnumeratorは現在の値のみを返します。
ハッシュテーブル/辞書はのペアをと表し、.Key
と.Value
を列挙しています。これは、Dictionary<TKey,TValue>
がIEnumerable<KeyValuePair<TKey, TValue>>
を実装しているので、2.0から少し気になります。
このインターフェイスでは、いくつかのケースでキー/値にアクセスする方が簡単です。 - 例
がforeach(DictionaryEntry pair in hashTable) {
.... use pair.Key and pair.Value
}
このインタフェースは、単にいくつかのケースでは、キー/値にアクセスすることがより便利になります:
あなたは経由(
IDictionaryEnumerator
を使用せずに)Hashtable
で同じことを達成することができますか?あなたは例を挙げることができますか? – AdamFo