Enumerable.Skip<TSource>(IEnumerable<TSource>, Int32) Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Пропускает заданное число элементов в последовательности и возвращает остальные элементы.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Collections::Generic::IEnumerable<TSource> ^ Skip(System::Collections::Generic::IEnumerable<TSource> ^ source, int count);
public static System.Collections.Generic.IEnumerable<TSource> Skip<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, int count);
static member Skip : seq<'Source> * int -> seq<'Source>
<Extension()>
Public Function Skip(Of TSource) (source As IEnumerable(Of TSource), count As Integer) As IEnumerable(Of TSource)
Параметры типа
- TSource
Тип элементов source
.
Параметры
- source
- IEnumerable<TSource>
Объект IEnumerable<T>, из которого требуется возвратить элементы.
- count
- Int32
Число элементов, пропускаемых перед возвращением остальных элементов.
Возвращаемое значение
Объект IEnumerable<T>, содержащий элементы из входной последовательности, начиная с указанного индекса.
Исключения
source
имеет значение null
.
Примеры
В следующем примере кода показано, как использовать для Skip пропуска указанного числа элементов в массиве и возврата оставшихся элементов.
int[] grades = { 59, 82, 70, 56, 92, 98, 85 };
Console.WriteLine("All grades except the first three:");
foreach (int grade in grades.Skip(3))
{
Console.WriteLine(grade);
}
/*
This code produces the following output:
All grades except the first three:
56
92
98
85
*/
' Create an array of integers that represent grades.
Dim grades() As Integer = {59, 82, 70, 56, 92, 98, 85}
' Sort the numbers in descending order and
' get all but the first (largest) three numbers.
Dim skippedGrades As IEnumerable(Of Integer) =
grades _
.Skip(3)
' Display the results.
Dim output As New System.Text.StringBuilder("All grades except the first three are:" & vbCrLf)
For Each grade As Integer In skippedGrades
output.AppendLine(grade)
Next
Console.WriteLine(output.ToString())
' This code produces the following output:
'
' All grades except the first three are:
' 56
' 92
' 98
' 85
Комментарии
Этот метод реализуется с помощью отложенного выполнения. Немедленное возвращаемое значение — это объект, в котором хранятся все сведения, необходимые для выполнения действия. Запрос, представленный этим методом, не выполняется, пока объект не будет перечислен либо путем вызова его GetEnumerator
метода напрямую, либо с помощью foreach
в C# или For Each
в Visual Basic.
Если source
содержит меньше count
элементов, возвращается пустое IEnumerable<T> значение. Если count
значение меньше или равно нулю, возвращаются все элементы source
.
Методы Take и Skip являются функциональными дополнениями. При использовании последовательности coll
коллекции и целого числа n
объединение результатов coll.Take(n)
и возвращает ту же последовательность, что coll
и coll.Skip(n)
.
В синтаксисе Skip
выражения запроса Visual Basic предложение преобразуется в вызов Skip.