Enumerable.Take Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Перегрузки
Take<TSource>(IEnumerable<TSource>, Int32) |
Возвращает указанное число подряд идущих элементов с начала последовательности. |
Take<TSource>(IEnumerable<TSource>, Range) |
Возвращает указанный диапазон смежных элементов из последовательности. |
Take<TSource>(IEnumerable<TSource>, Int32)
- Исходный код:
- Take.cs
- Исходный код:
- Take.cs
- Исходный код:
- Take.cs
Возвращает указанное число подряд идущих элементов с начала последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Collections::Generic::IEnumerable<TSource> ^ Take(System::Collections::Generic::IEnumerable<TSource> ^ source, int count);
public static System.Collections.Generic.IEnumerable<TSource> Take<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, int count);
static member Take : seq<'Source> * int -> seq<'Source>
<Extension()>
Public Function Take(Of TSource) (source As IEnumerable(Of TSource), count As Integer) As IEnumerable(Of TSource)
Параметры типа
- TSource
Тип элементов source
.
Параметры
- source
- IEnumerable<TSource>
Последовательность, из которой требуется возвратить элементы.
- count
- Int32
Число возвращаемых элементов.
Возвращаемое значение
Объект IEnumerable<T>, содержащий заданное число элементов с начала входной последовательности.
Исключения
source
имеет значение null
.
Примеры
В следующем примере кода показано, как использовать Take для возврата элементов из начала последовательности.
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
*/
' Create an array of Integer values that represent grades.
Dim grades() As Integer = {59, 82, 70, 56, 92, 98, 85}
' Get the highest three grades by first sorting
' them in descending order and then taking the
' first three values.
Dim topThreeGrades As IEnumerable(Of Integer) =
grades _
.OrderByDescending(Function(grade) grade) _
.Take(3)
' Display the results.
Dim output As New System.Text.StringBuilder("The top three grades are:" & vbCrLf)
For Each grade As Integer In topThreeGrades
output.AppendLine(grade)
Next
Console.WriteLine(output.ToString())
' 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.
См. также раздел
Применяется к
Take<TSource>(IEnumerable<TSource>, Range)
- Исходный код:
- Take.cs
- Исходный код:
- Take.cs
- Исходный код:
- Take.cs
Возвращает указанный диапазон смежных элементов из последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Collections::Generic::IEnumerable<TSource> ^ Take(System::Collections::Generic::IEnumerable<TSource> ^ source, Range range);
public static System.Collections.Generic.IEnumerable<TSource> Take<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Range range);
static member Take : seq<'Source> * Range -> seq<'Source>
<Extension()>
Public Function Take(Of TSource) (source As IEnumerable(Of TSource), range As Range) As IEnumerable(Of TSource)
Параметры типа
- TSource
Тип элементов source
.
Параметры
- source
- IEnumerable<TSource>
Последовательность, из которой требуется возвратить элементы.
- range
- Range
Диапазон возвращаемых элементов, который имеет начальный и конечный индексы от начала или конца последовательности.
Возвращаемое значение
Объект , IEnumerable<T> содержащий указанный диапазон элементов из source
последовательности.
Исключения
source
имеет значение null
.
Комментарии
Этот метод реализуется с помощью отложенного выполнения. Немедленное возвращаемое значение — это объект, в котором хранятся все сведения, необходимые для выполнения действия. Запрос, представленный этим методом, не выполняется, пока объект не будет перечислен либо путем вызова его GetEnumerator
метода напрямую, либо с помощью foreach
в C# или For Each
в Visual Basic.
Take перечисляет source
и возвращает элементы, индексы которых принадлежат указанному range
объекту .