Enumerable.Take Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Sobrecargas
| Name | Description |
|---|---|
| Take<TSource>(IEnumerable<TSource>, Int32) |
Devolve um número especificado de elementos contíguos do início de uma sequência. |
| Take<TSource>(IEnumerable<TSource>, Range) |
Devolve um intervalo especificado de elementos contíguos de uma sequência. |
Take<TSource>(IEnumerable<TSource>, Int32)
- Origem:
- Take.cs
- Origem:
- Take.cs
- Origem:
- Take.cs
- Origem:
- Take.cs
- Origem:
- Take.cs
Devolve um número especificado de elementos contíguos do início de uma sequência.
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)
Parâmetros de Tipo Genérico
- TSource
O tipo dos elementos de source.
Parâmetros
- source
- IEnumerable<TSource>
A sequência para devolver elementos de.
- count
- Int32
O número de elementos a devolver.
Devoluções
E IEnumerable<T> que contém o número especificado de elementos desde o início da sequência de entrada.
Exceções
source é null.
Exemplos
O exemplo de código seguinte demonstra como usar Take para devolver elementos do início de uma sequência (depois de esta estar ordenada).
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
Observações
Este método é implementado através da execução diferida. O valor de retorno imediato é um objeto que armazena toda a informação necessária para realizar a ação. A consulta representada por este método não é executada até que o objeto seja enumerado, seja chamando diretamente o seu método GetEnumerator ou usando foreach em C# ou For Each em Visual Basic.
Take enumera source e produz elementos até count que os elementos tenham sido fornecidos ou source não contenham mais elementos. Se count exceder o número de elementos em source, todos os elementos de source são devolvidos.
Se count for menor ou igual a zero, source não é enumerado e um vazio IEnumerable<T> é devolvido.
Os Take métodos e Skip são complementos funcionais. Dada uma sequência coll de coleção e um inteiro n, concatenar os resultados de coll.Take(n) e coll.Skip(n) produz a mesma sequência que coll.
Na sintaxe Visual Basic expressão de consulta, uma cláusula Take traduz-se numa invocação de Take.
Ver também
Aplica-se a
Take<TSource>(IEnumerable<TSource>, Range)
- Origem:
- Take.cs
- Origem:
- Take.cs
- Origem:
- Take.cs
- Origem:
- Take.cs
- Origem:
- Take.cs
Devolve um intervalo especificado de elementos contíguos de uma sequência.
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)
Parâmetros de Tipo Genérico
- TSource
O tipo dos elementos de source.
Parâmetros
- source
- IEnumerable<TSource>
A sequência para devolver elementos de.
- range
- Range
O intervalo de elementos a devolver, que tem índices de início e fim, seja do início ou do fim da sequência.
Devoluções
Um IEnumerable<T> que contém o intervalo especificado de elementos da source sequência.
Exceções
source é null.
Observações
Este método é implementado através da execução diferida. O valor de retorno imediato é um objeto que armazena toda a informação necessária para realizar a ação. A consulta representada por este método não é executada até que o objeto seja enumerado, seja chamando diretamente o seu método GetEnumerator ou usando foreach em C# ou For Each em Visual Basic.
Take enumera source e produz elementos cujos índices pertencem ao especificado range.