Como: consulta um ArrayList com LINQ

Ao usar o LINQ a consulta não genérico IEnumerable coleções, como ArrayList, você deve declarar explicitamente o tipo da variável de intervalo para refletir o tipo específico de objetos na coleção.Por exemplo, se você tiver um ArrayList de Student objetos, o cláusula from (C#) ou (Visual Basic) da cláusula FROM deve ficar assim:

// C#
var query = from Student s in arrList
... 
'Visual Basic
Dim query = From student As Student In arrList 
...

Especificando o tipo de variável de intervalo, a cada item são projeção do ArrayList para um Student.

O uso de uma variável de intervalo explicitamente digitado em uma expressão de consulta é equivalente a chamar o Cast<TResult> método.Cast<TResult>lança uma exceção se a conversão especificada não pode ser executada.Cast<TResult>e OfType<TResult> são os dois métodos de operador de consulta padrão operam em não-genéricas IEnumerable tipos.Na Visual Basic, você deve explicitamente chamar o Cast<TResult> método na fonte de dados para garantir que um tipo de variável de intervalo específico.Para obter mais informações, consulteRelações de tipo em operações de consulta (Visual Basic) e Relações de tipo em operações de consulta do LINQ (C#).

Exemplo

O exemplo a seguir mostra uma consulta simples através de um ArrayList.Observe que este exemplo usa os inicializadores de objeto quando o código chama o Add método, mas isso não é um requisito.

Imports System.Collections
Imports System.Linq

Module Module1

    Public Class Student
        Public Property FirstName As String
        Public Property LastName As String
        Public Property Scores As Integer()
    End Class

    Sub Main()

        Dim student1 As New Student With {.FirstName = "Svetlana", 
                                     .LastName = "Omelchenko", 
                                     .Scores = New Integer() {98, 92, 81, 60}}
        Dim student2 As New Student With {.FirstName = "Claire", 
                                    .LastName = "O'Donnell", 
                                    .Scores = New Integer() {75, 84, 91, 39}}
        Dim student3 As New Student With {.FirstName = "Cesar", 
                                    .LastName = "Garcia", 
                                    .Scores = New Integer() {97, 89, 85, 82}}
        Dim student4 As New Student With {.FirstName = "Sven", 
                                    .LastName = "Mortensen", 
                                    .Scores = New Integer() {88, 94, 65, 91}}

        Dim arrList As New ArrayList()
        arrList.Add(student1)
        arrList.Add(student2)
        arrList.Add(student3)
        arrList.Add(student4)

        ' Use an explicit type for non-generic collections
        Dim query = From student As Student In arrList 
                    Where student.Scores(0) > 95 
                    Select student

        For Each student As Student In query
            Console.WriteLine(student.LastName & ": " & student.Scores(0))
        Next
        ' Keep the console window open in debug mode.
        Console.WriteLine("Press any key to exit.")
        Console.ReadKey()
    End Sub

End Module
' Output:
'   Omelchenko: 98
'   Garcia: 97
using System;
using System.Collections;
using System.Linq;

namespace NonGenericLINQ
{
    public class Student
    {
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public int[] Scores { get; set; }
    }

    class Program
    {
        static void Main(string[] args)
        {
            ArrayList arrList = new ArrayList();
            arrList.Add(
                new Student
                    {
                        FirstName = "Svetlana", LastName = "Omelchenko", Scores = new int[] { 98, 92, 81, 60 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Claire", LastName = "O’Donnell", Scores = new int[] { 75, 84, 91, 39 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Sven", LastName = "Mortensen", Scores = new int[] { 88, 94, 65, 91 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Cesar", LastName = "Garcia", Scores = new int[] { 97, 89, 85, 82 }
                    });

            var query = from Student student in arrList
                        where student.Scores[0] > 95
                        select student;

            foreach (Student s in query)
                Console.WriteLine(s.LastName + ": " + s.Scores[0]);

            // Keep the console window open in debug mode.
            Console.WriteLine("Press any key to exit.");
            Console.ReadKey();
        }
    }
}
/* Output: 
    Omelchenko: 98
    Garcia: 97
*/

Consulte também

Conceitos

LINQ to Objects