Enumerable.Take Metodo

Definizione

Overload

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

Restituisce un numero specificato di elementi contigui dall'inizio di una sequenza.

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

Restituisce un intervallo specificato di elementi contigui da una sequenza.

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

Restituisce un numero specificato di elementi contigui dall'inizio di una sequenza.

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)

Parametri di tipo

TSource

Tipo degli elementi di source.

Parametri

source
IEnumerable<TSource>

Sequenza dalla quale vengono restituiti gli elementi.

count
Int32

Numero di elementi da restituire.

Restituisce

IEnumerable<TSource>

Oggetto IEnumerable<T> che contiene il numero specificato di elementi, dall'inizio della sequenza di input.

Eccezioni

source è null.

Esempio

Nell'esempio di codice seguente viene illustrato come Take utilizzare per restituire elementi dall'inizio di una sequenza.

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

Commenti

Questo metodo viene implementato tramite 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 il relativo metodo direttamente o usando GetEnumerator foreach in Visual C# o in For Each Visual Basic.

Take enumera e source restituisce elementi fino a quando gli elementi non sono stati count cedeti o source non contengono più elementi. Se count supera il numero di elementi in , vengono source restituiti tutti gli elementi di source .

Se count è minore o uguale a zero, non viene source enumerato e viene restituito IEnumerable<T> un valore vuoto.

I Take metodi e sono Skip complementi funzionali. Data una sequenza di coll raccolta e un intero , la n concatenazione dei risultati di e coll.Take(n) produce la stessa sequenza di coll.Skip(n) coll .

In Visual Basic sintassi dell'espressione di query, una Take clausola si traduce in una chiamata di Take .

Vedi anche

Si applica a

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

Restituisce un intervallo specificato di elementi contigui da una sequenza.

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)

Parametri di tipo

TSource

Tipo degli elementi di source.

Parametri

source
IEnumerable<TSource>

Sequenza dalla quale vengono restituiti gli elementi.

range
Range

Intervallo di elementi da restituire, che contiene gli indici iniziale e finale dall'inizio o dalla fine.

Restituisce

IEnumerable<TSource>

Oggetto IEnumerable<T> che contiene range l'oggetto specificato di elementi dalla source sequenza.

Eccezioni

source è null.

Commenti

Questo metodo viene implementato tramite 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 il relativo metodo direttamente o usando GetEnumerator foreach in Visual C# o in For Each Visual Basic.

Take enumera e source restituisce gli elementi i cui indici appartengono all'oggetto range specificato.

Si applica a