ReadOnlyCollection<T>.Contains(T) Yöntem

Tanım

bir öğenin içinde ReadOnlyCollection<T>olup olmadığını belirler.

C#
public bool Contains (T value);

Parametreler

value
T

içinde ReadOnlyCollection<T>bulunacak nesne. Değer başvuru türleri için olabilir null .

Döndürülenler

true içinde bulunursa valueReadOnlyCollection<T>; değilse, false.

Uygulamalar

Örnekler

Aşağıdaki kod örneği, sınıfın birkaç üyesini ReadOnlyCollection<T> gösterir. Kod örneği bir List<T> dize oluşturur ve buna dört dinozor adı ekler. Kod örneği daha sonra listeyi bir ReadOnlyCollection<T>içinde sarmalar.

, , Item[]Contains, ve IList.IndexOf üyelerini gösterdikten Countsonra kod örneği, öğesine yeni bir öğe ekleyerek ve içeriğini görüntüleyerek öğesinin ReadOnlyCollection<T>yalnızca özgün List<T> için List<T> bir sarmalayıcı olduğunu gösterirReadOnlyCollection<T>.

Son olarak, kod örneği koleksiyonundan daha büyük bir dizi oluşturur ve yöntemini kullanarak CopyTo koleksiyonun öğelerini dizinin ortasına ekler.

C#
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;

public class Example
{
    public static void Main()
    {
        List<string> dinosaurs = new List<string>();

        dinosaurs.Add("Tyrannosaurus");
        dinosaurs.Add("Amargasaurus");
        dinosaurs.Add("Deinonychus");
        dinosaurs.Add("Compsognathus");

        ReadOnlyCollection<string> readOnlyDinosaurs =
            new ReadOnlyCollection<string>(dinosaurs);

        Console.WriteLine();
        foreach( string dinosaur in readOnlyDinosaurs )
        {
            Console.WriteLine(dinosaur);
        }

        Console.WriteLine("\nCount: {0}", readOnlyDinosaurs.Count);

        Console.WriteLine("\nContains(\"Deinonychus\"): {0}",
            readOnlyDinosaurs.Contains("Deinonychus"));

        Console.WriteLine("\nreadOnlyDinosaurs[3]: {0}",
            readOnlyDinosaurs[3]);

        Console.WriteLine("\nIndexOf(\"Compsognathus\"): {0}",
            readOnlyDinosaurs.IndexOf("Compsognathus"));

        Console.WriteLine("\nInsert into the wrapped List:");
        Console.WriteLine("Insert(2, \"Oviraptor\")");
        dinosaurs.Insert(2, "Oviraptor");

        Console.WriteLine();
        foreach( string dinosaur in readOnlyDinosaurs )
        {
            Console.WriteLine(dinosaur);
        }

        string[] dinoArray = new string[readOnlyDinosaurs.Count + 2];
        readOnlyDinosaurs.CopyTo(dinoArray, 1);

        Console.WriteLine("\nCopied array has {0} elements:",
            dinoArray.Length);
        foreach( string dinosaur in dinoArray )
        {
            Console.WriteLine("\"{0}\"", dinosaur);
        }
    }
}

/* This code example produces the following output:

Tyrannosaurus
Amargasaurus
Deinonychus
Compsognathus

Count: 4

Contains("Deinonychus"): True

readOnlyDinosaurs[3]: Compsognathus

IndexOf("Compsognathus"): 3

Insert into the wrapped List:
Insert(2, "Oviraptor")

Tyrannosaurus
Amargasaurus
Oviraptor
Deinonychus
Compsognathus

Copied array has 7 elements:
""
"Tyrannosaurus"
"Amargasaurus"
"Oviraptor"
"Deinonychus"
"Compsognathus"
""
 */

Açıklamalar

Bu yöntem, varsayılan eşitlik karşılaştırıcısını EqualityComparer<T>.Defaultkullanarak eşitliği belirler.

Bu yöntem doğrusal bir arama gerçekleştirir; bu nedenle, bu yöntem bir O(n) işlemidir ve burada n şeklindedir Count.

Şunlara uygulanır

Ü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 2.0, 3.0, 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.5, 1.6, 2.0, 2.1
UWP 10.0

Ayrıca bkz.