Прочитать на английском

Поделиться через


Enumerable.Take Метод

Определение

Перегрузки

Take<TSource>(IEnumerable<TSource>, Int32)

Возвращает указанное число подряд идущих элементов с начала последовательности.

Take<TSource>(IEnumerable<TSource>, Range)

Возвращает указанный диапазон смежных элементов из последовательности.

Take<TSource>(IEnumerable<TSource>, Int32)

Исходный код:
Take.cs
Исходный код:
Take.cs
Исходный код:
Take.cs

Возвращает указанное число подряд идущих элементов с начала последовательности.

C#
public static System.Collections.Generic.IEnumerable<TSource> Take<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, int count);

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

TSource

Тип элементов source.

Параметры

source
IEnumerable<TSource>

Последовательность, из которой требуется возвратить элементы.

count
Int32

Число возвращаемых элементов.

Возвращаемое значение

IEnumerable<TSource>

Объект IEnumerable<T>, содержащий заданное число элементов с начала входной последовательности.

Исключения

source имеет значение null.

Примеры

В следующем примере кода показано, как использовать Take для возврата элементов из начала последовательности.

C#
int[] grades = { 59, 82, 70, 56, 92, 98, 85 };

IEnumerable<int> topThreeGrades =
    grades.OrderByDescending(grade => grade).Take(3);

Console.WriteLine("The top three grades are:");
foreach (int grade in topThreeGrades)
{
    Console.WriteLine(grade);
}
/*
 This code produces the following output:

 The top three grades are:
 98
 92
 85
*/

Комментарии

Этот метод реализуется с помощью отложенного выполнения. Немедленное возвращаемое значение — это объект, в котором хранятся все сведения, необходимые для выполнения действия. Запрос, представленный этим методом, не выполняется, пока объект не будет перечислен либо путем вызова его GetEnumerator метода напрямую, либо с помощью foreach в C# или For Each в Visual Basic.

Take перечисляет source и возвращает элементы до тех пор, пока элементы не count будут возвращены или source не содержат больше элементов. Если count превышает число элементов в source, возвращаются все элементы source .

Если count значение меньше или равно нулю, source не перечисляется и возвращается пустое IEnumerable<T> значение.

Методы Take и Skip являются функциональными дополнениями. При использовании последовательности coll коллекции и целого числа nобъединение результатов coll.Take(n) и возвращает ту же последовательность, что collи coll.Skip(n) .

В синтаксисе Take выражения запроса Visual Basic предложение преобразуется в вызов Take.

См. также раздел

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

.NET 9 и другие версии
Продукт Версии
.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

Take<TSource>(IEnumerable<TSource>, Range)

Исходный код:
Take.cs
Исходный код:
Take.cs
Исходный код:
Take.cs

Возвращает указанный диапазон смежных элементов из последовательности.

C#
public static System.Collections.Generic.IEnumerable<TSource> Take<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Range range);

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

TSource

Тип элементов source.

Параметры

source
IEnumerable<TSource>

Последовательность, из которой требуется возвратить элементы.

range
Range

Диапазон возвращаемых элементов, который имеет начальный и конечный индексы от начала или конца последовательности.

Возвращаемое значение

IEnumerable<TSource>

Объект , IEnumerable<T> содержащий указанный диапазон элементов из source последовательности.

Исключения

source имеет значение null.

Комментарии

Этот метод реализуется с помощью отложенного выполнения. Немедленное возвращаемое значение — это объект, в котором хранятся все сведения, необходимые для выполнения действия. Запрос, представленный этим методом, не выполняется, пока объект не будет перечислен либо путем вызова его GetEnumerator метода напрямую, либо с помощью foreach в C# или For Each в Visual Basic.

Take перечисляет source и возвращает элементы, индексы которых принадлежат указанному rangeобъекту .

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

.NET 9 и другие версии
Продукт Версии
.NET 6, 7, 8, 9