Enumerable.Intersect Yöntem

Tanım

İki dizinin küme kesişimini üretir.

Aşırı Yüklemeler

Intersect<TSource>(IEnumerable<TSource>, IEnumerable<TSource>)

Değerleri karşılaştırmak için varsayılan eşitlik karşılaştırıcısını kullanarak iki dizinin küme kesişimini üretir.

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

Değerleri karşılaştırmak için belirtilen IEqualityComparer<T> öğesini kullanarak iki dizinin küme kesişimini üretir.

Intersect<TSource>(IEnumerable<TSource>, IEnumerable<TSource>)

Kaynak:
Intersect.cs
Kaynak:
Intersect.cs
Kaynak:
Intersect.cs

Değerleri karşılaştırmak için varsayılan eşitlik karşılaştırıcısını kullanarak iki dizinin küme kesişimini üretir.

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

Tür Parametreleri

TSource

Giriş dizilerinin öğelerinin türü.

Parametreler

first
IEnumerable<TSource>

IEnumerable<T> içinde de görünen second benzersiz öğeleri döndürülür.

second
IEnumerable<TSource>

IEnumerable<T> İlk dizide de görünen benzersiz öğeleri döndürülür.

Döndürülenler

IEnumerable<TSource>

İki dizinin küme kesişimini oluşturan öğeleri içeren bir dizi.

Özel durumlar

first veya second şeklindedir null.

Örnekler

Aşağıdaki kod örneği, iki tamsayı dizisinde görünen öğeleri döndürmek için nasıl kullanılacağını Intersect<TSource>(IEnumerable<TSource>, IEnumerable<TSource>) gösterir.

C#
int[] id1 = { 44, 26, 92, 30, 71, 38 };
int[] id2 = { 39, 59, 83, 47, 26, 4, 30 };

IEnumerable<int> both = id1.Intersect(id2);

foreach (int id in both)
    Console.WriteLine(id);

/*
 This code produces the following output:

 26
 30
*/

Bazı özel veri türlerindeki nesne dizilerini karşılaştırmak istiyorsanız, yardımcı sınıfta genel arabirimi uygulamanız IEquatable<T> gerekir. Aşağıdaki kod örneği, bu arabirimin özel bir veri türünde nasıl uygulanıp geçersiz kılınıp ve Equals yöntemlerin nasıl uygulanıp uygulanmayacaklarını GetHashCode gösterir.

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();
}

Bu arabirimi uyguladıktan sonra, aşağıdaki örnekte gösterildiği gibi yöntemindeki Intersect nesne dizilerini ProductA kullanabilirsiniz:

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 first array
// that have duplicates in the second array.

IEnumerable<ProductA> duplicates =
    store1.Intersect(store2);

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

/*
    This code produces the following output:
    apple 9
*/

Açıklamalar

Bu yöntem ertelenmiş yürütme kullanılarak uygulanır. Hemen dönüş değeri, eylemi gerçekleştirmek için gereken tüm bilgileri depolayan bir nesnedir. Bu yöntemle temsil edilen sorgu, doğrudan yöntemini çağırarak GetEnumerator veya C# içinde veya For Each Visual Basic'te kullanarak foreach nesne numaralandırılana kadar yürütülür.

A ve B kümelerinin kesişimi, A'nın B'de de görünen tüm öğelerini içeren küme olarak tanımlanır, ancak başka öğe yoktur.

Bu yöntem tarafından döndürülen nesne numaralandırıldığında, Intersect her iki dizide de oluşan benzersiz öğeleri içinde firstgöründükleri sırayla verir.

Türlerin değerlerini karşılaştırmak için varsayılan eşitlik karşılaştırıcısı Defaultkullanılır. Özel bir veri türünü karşılaştırmak için ve GetHashCode yöntemlerini geçersiz kılmanız Equals ve isteğe bağlı olarak özel türdeki genel arabirimi uygulamanız IEquatable<T> gerekir. Daha fazla bilgi için özelliğine Default bakın.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.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

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

Kaynak:
Intersect.cs
Kaynak:
Intersect.cs
Kaynak:
Intersect.cs

Değerleri karşılaştırmak için belirtilen IEqualityComparer<T> öğesini kullanarak iki dizinin küme kesişimini üretir.

C#
public static System.Collections.Generic.IEnumerable<TSource> Intersect<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> Intersect<TSource> (this System.Collections.Generic.IEnumerable<TSource> first, System.Collections.Generic.IEnumerable<TSource> second, System.Collections.Generic.IEqualityComparer<TSource>? comparer);

Tür Parametreleri

TSource

Giriş dizilerinin öğelerinin türü.

Parametreler

first
IEnumerable<TSource>

IEnumerable<T> içinde de görünen second benzersiz öğeleri döndürülür.

second
IEnumerable<TSource>

IEnumerable<T> İlk dizide de görünen benzersiz öğeleri döndürülür.

comparer
IEqualityComparer<TSource>

Değerleri karşılaştırmak için bir IEqualityComparer<T> .

Döndürülenler

IEnumerable<TSource>

İki dizinin küme kesişimini oluşturan öğeleri içeren bir dizi.

Özel durumlar

first veya second şeklindedir null.

Örnekler

Aşağıdaki örnekte yönteminde kullanılabilecek bir eşitlik karşılaştırıcısının nasıl uygulanacağı gösterilmektedir Intersect .

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;
    }
}

Bu karşılaştırıcıyı uyguladıktan sonra, aşağıdaki örnekte gösterildiği gibi yöntemindeki Intersect nesne dizilerini Product kullanabilirsiniz:

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

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

// Get the products from the first array
// that have duplicates in the second array.

IEnumerable<Product> duplicates =
    store1.Intersect(store2, new ProductComparer());

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

/*
    This code produces the following output:
    apple 9
*/

Açıklamalar

Bu yöntem ertelenmiş yürütme kullanılarak uygulanır. Hemen dönüş değeri, eylemi gerçekleştirmek için gereken tüm bilgileri depolayan bir nesnedir. Bu yöntemle temsil edilen sorgu, doğrudan yöntemini çağırarak GetEnumerator veya C# içinde veya For Each Visual Basic'te kullanarak foreach nesne numaralandırılana kadar yürütülür.

A ve B kümelerinin kesişimi, A'nın B'de de görünen tüm öğelerini içeren küme olarak tanımlanır, ancak başka öğe yoktur.

Bu yöntem tarafından döndürülen nesne numaralandırıldığında, Intersect her iki dizide de oluşan benzersiz öğeleri içinde firstgöründükleri sırayla verir.

ise comparernull, değerleri karşılaştırmak için varsayılan eşitlik karşılaştırıcısı Defaultkullanılır.

Şunlara uygulanır

.NET 9 ve diğer sürümler
Ürün Sürümler
.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