Вопрос

Я посмотрел это в сети, но я прошу это, чтобы убедиться, что я ничего не пропустил. Есть ли встроенная функция для преобразования HashSets в списки в C #? Мне нужно избегать дублирования элементов, но мне нужно возвращать список.

Это было полезно?

Решение

Вот как бы я это сделал:

   using System.Linq;
   HashSet<int> hset = new HashSet<int>();
   hset.Add(10);
   List<int> hList= hset.ToList();

HashSet по определению не содержит дубликатов. Так что нет необходимости в Distinct.

Другие советы

Два эквивалентных варианта:

HashSet<string> stringSet = new HashSet<string> { "a", "b", "c" };
// LINQ's ToList extension method
List<string> stringList1 = stringSet.ToList();
// Or just a constructor
List<string> stringList2 = new List<string>(stringSet);

Лично я предпочел бы позвонить ToList, это означает, что вам не нужно повторно указывать тип списка.

Вопреки моим предыдущим мыслям, оба способа позволяют легко выразить ковариацию в C # 4:

    HashSet<Banana> bananas = new HashSet<Banana>();        
    List<Fruit> fruit1 = bananas.ToList<Fruit>();
    List<Fruit> fruit2 = new List<Fruit>(bananas);

Для этого есть метод расширения Linq ToList<T>() (он определен в IEnumerable<T>, который реализован HashSet<T>).

Просто убедитесь, что вы using System.Linq;

Как вы, очевидно, знаете, HashSet гарантирует, что у вас нет дубликатов, и эта функция позволит вам вернуть его как IList<T>.

List<ListItemType> = new List<ListItemType>(hashSetCollection);
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top