Array.Find<T>(T[], Predicate<T>) Метод

Определение

Выполняет поиск элемента, удовлетворяющего условиям указанного предиката, и возвращает первое найденное вхождение в пределах всего списка Array.Searches for an element that matches the conditions defined by the specified predicate, and returns the first occurrence within the entire Array.

public:
generic <typename T>
 static T Find(cli::array <T> ^ array, Predicate<T> ^ match);
public static T Find<T> (T[] array, Predicate<T> match);
static member Find : 'T[] * Predicate<'T> -> 'T
Public Shared Function Find(Of T) (array As T(), match As Predicate(Of T)) As T

Параметры типа

T

Тип элементов массива.The type of the elements of the array.

Параметры

array
T[]

Индексируемый от нуля одномерный массив, в котором выполняется поиск.The one-dimensional, zero-based array to search.

match
Predicate<T>

Предикат, определяющий условия элемента, который требуется найти.The predicate that defines the conditions of the element to search for.

Возвраты

T

Первый элемент, удовлетворяющий условиям указанного предиката, если такой элемент найден; в противном случае — значение по умолчанию для типа T.The first element that matches the conditions defined by the specified predicate, if found; otherwise, the default value for type T.

Исключения

Свойство array имеет значение null.array is null.

- или --or- Свойство match имеет значение null.match is null.

Примеры

В следующем примере используется делегат Predicate<T> с универсальным методом Find для поиска в массиве структур Point.The following example uses a Predicate<T> delegate with the Find generic method to search an array of Point structures. Метод, который представляет делегат, ProductGT10, возвращает true, если произведение полей X и Y превышает 100 000.The method the delegate represents, ProductGT10, returns true if the product of the X and Y fields is greater than 100,000. Метод Find вызывает делегат для каждого элемента массива, возвращая первую точку, удовлетворяющую условию теста.The Find method calls the delegate for each element of the array, returning the first point that meets the test condition.

Примечание

Visual Basic и C# пользователям не нужно явно создавать делегат или указывать аргумент типа для универсального метода.Visual Basic and C# users do not have to create the delegate explicitly or specify the type argument of the generic method. Компиляторы определяют необходимые типы из предоставленных аргументов метода.The compilers determine the necessary types from the method arguments you supply.

using System;
using System.Drawing;

public class Example
{
    public static void Main()
    {
        // Create an array of five Point structures.
        Point[] points = { new Point(100, 200), 
            new Point(150, 250), new Point(250, 375), 
            new Point(275, 395), new Point(295, 450) };

        // Find the first Point structure for which X times Y 
        // is greater than 100000. 
        Point first = Array.Find(points, ProductGT10);

        // Display the first structure found.
        Console.WriteLine("Found: X = {0}, Y = {1}", first.X, first.Y);
    }

    // Return true if X times Y is greater than 100000.
    private static bool ProductGT10(Point p)
    {
        return p.X * p.Y > 100000;
    }
}
// The example displays the following output:
//       Found: X = 275, Y = 395
Imports System.Drawing

Public Module Example
   Public Sub Main()
      ' Create an array of five Point structures.
      Dim points() As Point = { new Point(100, 200), _
            new Point(150, 250), new Point(250, 375), _
            new Point(275, 395), new Point(295, 450) }

      ' Find the first Point structure for which X times Y 
      ' is greater than 100000. 
      Dim first As Point = Array.Find(points, AddressOf ProductGT10)

      ' Display the first structure found.
      Console.WriteLine("Found: X = {0}, Y = {1}", _
            first.X, first.Y)
   End Sub

   ' Return true if X times Y is greater than 100000.
   Private Function ProductGT10(ByVal p As Point) As Boolean
      Return p.X * p.Y > 100000 
   End Function
End Module
' The example displays the following output:
'       Found: X = 275, Y = 395

Вместо явного определения метода с необходимой сигнатурой, создания экземпляра делегата Predicate<T> и передачи делегата в метод Find, пользователь может использовать лямбда-выражение.Rather than explicitly defining a method with the necessary signature, instantiating a Predicate<T> delegate, and passing the delegate to the Find method, it is customary to use a lambda expression. Следующий пример идентичен предыдущему, за исключением того, что в качестве аргумента match используется лямбда-выражение.The following example is identical to the previous one, except that it uses a lambda expression as the match argument.

using System;
using System.Drawing;

public class Example
{
    public static void Main()
    {
        // Create an array of five Point structures.
        Point[] points = { new Point(100, 200), 
            new Point(150, 250), new Point(250, 375), 
            new Point(275, 395), new Point(295, 450) };

        // Find the first Point structure for which X times Y 
        // is greater than 100000. 
        Point first = Array.Find(points, p => p.X * p.Y > 100000);

        // Display the first structure found.
        Console.WriteLine("Found: X = {0}, Y = {1}", first.X, first.Y);
    }
}
// The example displays the following output:
//       Found: X = 275, Y = 395
Imports System.Drawing

Public Module Example
   Public Sub Main()
      ' Create an array of five Point structures.
      Dim points() As Point = { new Point(100, 200), _
            new Point(150, 250), new Point(250, 375), _
            new Point(275, 395), new Point(295, 450) }

      ' Find the first Point structure for which X times Y 
      ' is greater than 100000. 
      Dim first As Point = Array.Find(points, 
                                      Function(p) p.X * p.Y > 100000)

      ' Display the first structure found.
      Console.WriteLine("Found: X = {0}, Y = {1}", _
            first.X, first.Y)
   End Sub
End Module
' The example displays the following output:
'       Found: X = 275, Y = 395

Комментарии

Predicate<T> является делегатом метода или лямбда-выражения, которое возвращает true, если переданный ему объект соответствует условиям, определенным в делегате или лямбда-выражении.The Predicate<T> is a delegate to a method or a lambda expression that returns true if the object passed to it matches the conditions defined in the delegate or lambda expression. Элементы array по отдельности передаются Predicate<T>, начиная с первого элемента и заканчивая последним элементом.The elements of array are individually passed to the Predicate<T>, starting with the first element and ending with the last element. Обработка останавливается при обнаружении соответствия.Processing is stopped when a match is found.

Этот метод является операцией O (n), где n является Length из array.This method is an O(n) operation, where n is the Length of array.

Применяется к

Дополнительно