Enumerable.Skip<TSource>(IEnumerable<TSource>, Int32) Metodo
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Ignora un numero specificato di elementi in una sequenza e quindi restituisce gli elementi rimanenti.
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)
Parametri di tipo
- TSource
Tipo degli elementi di source
.
Parametri
- source
- IEnumerable<TSource>
Oggetto IEnumerable<T> dal quale restituire elementi.
- count
- Int32
Il numero di elementi da ignorare prima di restituire gli elementi rimanenti.
Restituisce
Oggetto IEnumerable<T> che contiene gli elementi presenti dopo l'indice specificato nella sequenza di input.
Eccezioni
source
è null
.
Esempio
Nell'esempio di codice seguente viene illustrato come usare Skip per ignorare un numero specificato di elementi in una matrice e restituire gli elementi rimanenti.
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
Commenti
Questo metodo viene implementato usando l'esecuzione posticipata. Il valore restituito immediato è un oggetto che archivia tutte le informazioni necessarie per eseguire l'azione. La query rappresentata da questo metodo non viene eseguita fino a quando l'oggetto non viene enumerato chiamando direttamente il relativo GetEnumerator
metodo o usando foreach
in C# o For Each
in Visual Basic.
Se source
contiene meno di count
elementi, viene restituito un valore vuoto IEnumerable<T> . Se count
è minore o uguale a zero, vengono restituiti tutti gli elementi di source
.
I Take metodi e Skip sono complementi funzionali. Data una sequenza coll
di raccolta e un numero intero n
, concatenando i risultati di coll.Take(n)
e coll.Skip(n)
restituisce la stessa sequenza di coll
.
Nella sintassi delle espressioni di query di Visual Basic una Skip
clausola viene convertita in una chiamata di Skip.