Enumerable.Union Metoda

Definicja

Tworzy zbiór dwóch sekwencji.

Przeciążenia

Union<TSource>(IEnumerable<TSource>, IEnumerable<TSource>)

Tworzy zestaw unii dwóch sekwencji przy użyciu domyślnego porównania równości.

Union<TSource>(IEnumerable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>)

Tworzy zbiór dwóch sekwencji przy użyciu określonej IEqualityComparer<T>.

Union<TSource>(IEnumerable<TSource>, IEnumerable<TSource>)

Źródło:
Union.cs
Źródło:
Union.cs
Źródło:
Union.cs

Tworzy zestaw unii dwóch sekwencji przy użyciu domyślnego porównania równości.

C#
public static System.Collections.Generic.IEnumerable<TSource> Union<TSource> (this System.Collections.Generic.IEnumerable<TSource> first, System.Collections.Generic.IEnumerable<TSource> second);

Parametry typu

TSource

Typ elementów sekwencji wejściowych.

Parametry

first
IEnumerable<TSource>

IEnumerable<T>, którego odrębne elementy tworzą pierwszy zestaw dla unii.

second
IEnumerable<TSource>

IEnumerable<T>, którego odrębne elementy tworzą drugi zestaw dla unii.

Zwraca

IEnumerable<TSource>

IEnumerable<T>, który zawiera elementy z obu sekwencji wejściowych, z wyłączeniem duplikatów.

Wyjątki

first lub second jest null.

Przykłady

W poniższym przykładzie kodu pokazano, jak używać Union<TSource>(IEnumerable<TSource>, IEnumerable<TSource>) w celu uzyskania unii dwóch sekwencji liczb całkowitych.

C#
int[] ints1 = { 5, 3, 9, 7, 5, 9, 3, 7 };
int[] ints2 = { 8, 3, 6, 4, 4, 9, 1, 0 };

IEnumerable<int> union = ints1.Union(ints2);

foreach (int num in union)
{
    Console.Write("{0} ", num);
}

/*
 This code produces the following output:

 5 3 9 7 8 6 4 1 0
*/

Jeśli chcesz porównać sekwencje obiektów pewnego niestandardowego typu danych, musisz zaimplementować interfejs ogólny IEquatable<T> w klasie pomocniczej. Poniższy przykład kodu pokazuje, jak zaimplementować ten interfejs w niestandardowym typie danych i zastąpić metody GetHashCode i Equals.

C#
public class ProductA : IEquatable<ProductA>
{
    public string Name { get; set; }
    public int Code { get; set; }

    public bool Equals(ProductA other)
    {
        if (other is null)
            return false;

        return this.Name == other.Name && this.Code == other.Code;
    }

    public override bool Equals(object obj) => Equals(obj as ProductA);
    public override int GetHashCode() => (Name, Code).GetHashCode();
}

Po zaimplementowaniu tego interfejsu można użyć sekwencji obiektów ProductA w metodzie Union<TSource>(IEnumerable<TSource>, IEnumerable<TSource>), jak pokazano w poniższym przykładzie:

C#
ProductA[] store1 = { new ProductA { Name = "apple", Code = 9 },
                       new ProductA { Name = "orange", Code = 4 } };

ProductA[] store2 = { new ProductA { Name = "apple", Code = 9 },
                       new ProductA { Name = "lemon", Code = 12 } };
C#
//Get the products from the both arrays
//excluding duplicates.

IEnumerable<ProductA> union =
  store1.Union(store2);

foreach (var product in union)
    Console.WriteLine(product.Name + " " + product.Code);

/*
    This code produces the following output:

    apple 9
    orange 4
    lemon 12
*/

Uwagi

Ta metoda jest implementowana przy użyciu odroczonego wykonania. Natychmiastowa wartość zwracana to obiekt, który przechowuje wszystkie informacje wymagane do wykonania akcji. Zapytanie reprezentowane przez tę metodę nie jest wykonywane, dopóki obiekt nie zostanie wyliczony przez wywołanie metody GetEnumerator bezpośrednio lub przy użyciu foreach w języku C# lub For Each w Visual Basic.

Ta metoda wyklucza duplikaty z zestawu zwracanego. Jest to inne zachowanie metody Concat, która zwraca wszystkie elementy w sekwencjach wejściowych, w tym duplikaty.

Domyślny moduł porównywania równości, Default, służy do porównywania wartości typów, które implementują interfejs ogólny IEqualityComparer<T>. Aby porównać niestandardowy typ danych, należy zaimplementować ten interfejs i udostępnić własne metody GetHashCode i Equals dla typu.

Gdy obiekt zwrócony przez tę metodę jest wyliczany, Union wylicza first i second w tej kolejności i zwraca każdy element, który nie został jeszcze zwrócony.

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Union<TSource>(IEnumerable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>)

Źródło:
Union.cs
Źródło:
Union.cs
Źródło:
Union.cs

Tworzy zbiór dwóch sekwencji przy użyciu określonej IEqualityComparer<T>.

C#
public static System.Collections.Generic.IEnumerable<TSource> Union<TSource> (this System.Collections.Generic.IEnumerable<TSource> first, System.Collections.Generic.IEnumerable<TSource> second, System.Collections.Generic.IEqualityComparer<TSource> comparer);
C#
public static System.Collections.Generic.IEnumerable<TSource> Union<TSource> (this System.Collections.Generic.IEnumerable<TSource> first, System.Collections.Generic.IEnumerable<TSource> second, System.Collections.Generic.IEqualityComparer<TSource>? comparer);

Parametry typu

TSource

Typ elementów sekwencji wejściowych.

Parametry

first
IEnumerable<TSource>

IEnumerable<T>, którego odrębne elementy tworzą pierwszy zestaw dla unii.

second
IEnumerable<TSource>

IEnumerable<T>, którego odrębne elementy tworzą drugi zestaw dla unii.

comparer
IEqualityComparer<TSource>

IEqualityComparer<T> do porównywania wartości.

Zwraca

IEnumerable<TSource>

IEnumerable<T>, który zawiera elementy z obu sekwencji wejściowych, z wyłączeniem duplikatów.

Wyjątki

first lub second jest null.

Przykłady

W poniższym przykładzie pokazano, jak zaimplementować porównanie równości, którego można użyć w metodzie Union.

C#
public class Product
{
    public string Name { get; set; }
    public int Code { get; set; }
}

// Custom comparer for the Product class
class ProductComparer : IEqualityComparer<Product>
{
    // Products are equal if their names and product numbers are equal.
    public bool Equals(Product x, Product y)
    {

        //Check whether the compared objects reference the same data.
        if (Object.ReferenceEquals(x, y)) return true;

        //Check whether any of the compared objects is null.
        if (Object.ReferenceEquals(x, null) || Object.ReferenceEquals(y, null))
            return false;

        //Check whether the products' properties are equal.
        return x.Code == y.Code && x.Name == y.Name;
    }

    // If Equals() returns true for a pair of objects
    // then GetHashCode() must return the same value for these objects.

    public int GetHashCode(Product product)
    {
        //Check whether the object is null
        if (Object.ReferenceEquals(product, null)) return 0;

        //Get hash code for the Name field if it is not null.
        int hashProductName = product.Name == null ? 0 : product.Name.GetHashCode();

        //Get hash code for the Code field.
        int hashProductCode = product.Code.GetHashCode();

        //Calculate the hash code for the product.
        return hashProductName ^ hashProductCode;
    }
}

Po zaimplementowaniu tego porównania można użyć sekwencji obiektów Product w metodzie Union, jak pokazano w poniższym przykładzie:

C#
Product[] store10 = { new Product { Name = "apple", Code = 9 },
                       new Product { Name = "orange", Code = 4 } };

Product[] store20 = { new Product { Name = "apple", Code = 9 },
                       new Product { Name = "lemon", Code = 12 } };

//Get the products from the both arrays
//excluding duplicates.

IEnumerable<Product> union =
  store10.Union(store20, new ProductComparer());

foreach (Product product in union)
    Console.WriteLine(product.Name + " " + product.Code);

/*
    This code produces the following output:

    apple 9
    orange 4
    lemon 12
*/

Uwagi

Ta metoda jest implementowana przy użyciu odroczonego wykonania. Natychmiastowa wartość zwracana to obiekt, który przechowuje wszystkie informacje wymagane do wykonania akcji. Zapytanie reprezentowane przez tę metodę nie jest wykonywane, dopóki obiekt nie zostanie wyliczony przez wywołanie metody GetEnumerator bezpośrednio lub przy użyciu foreach w języku C# lub For Each w Visual Basic.

Jeśli comparer jest null, domyślnym porównaniem równości jest Default, służy do porównywania wartości.

Gdy obiekt zwrócony przez tę metodę jest wyliczany, Union wylicza first i second w tej kolejności i zwraca każdy element, który nie został jeszcze zwrócony.

Metoda Concat różni się od metody Union, ponieważ metoda Concat zwraca wszystkie elementy w sekwencjach wejściowych, w tym duplikaty, podczas gdy Union zwraca tylko unikatowe wartości.

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0