1

私がこのような方法を持っているとしましょう(Jon Skeetによる以前のSO回答から盗まれました):

public static IEnumerable<TSource> DuplicatesBy<TSource, TKey>
    (this IEnumerable<TSource> source, Func<TSource, TKey> keySelector)
{
    HashSet<TKey> seenKeys = new HashSet<TKey>();
    foreach (TSource element in source)
    {
        // Yield it if the key hasn't actually been added - i.e. it
        // was already in the set
        if (!seenKeys.Add(keySelector(element)))
        {
            yield return element;
        }
    }
}

このメソッドでは、表示されたキーを保持するために使用されるHashSetがあります。このような方法でこの方法を使用するとします。

List<string> strings = new List<string> { "1", "1", "2", "3" };
List<string> somewhatUniques = strings.DuplicatesBy(s => s).Take(2);

これは、文字列リストの最初の2つの項目のみを列挙します。しかし、ガベージコレクションはどのようにしてseenKeysハッシュセットを収集しますか。イールドはメソッドの実行を一時停止するだけなので、メソッドが高価な場合、どうすれば適切に処理できるかを確認できますか?

4

2 に答える 2