Procedura: eseguire una query su un ArrayList con LINQ

Quando si utilizza LINQ per eseguire una query su insiemi IEnumerable non generici, ad esempio ArrayList, è necessario dichiarare in modo esplicito il tipo della variabile di intervallo per riflettere il tipo specifico degli oggetti nell'insieme. Con un oggetto ArrayList di oggetti Student, la clausola from (C#) o la Clausola From (Visual Basic) deve ad esempio essere analoga alla seguente:

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

Specificando il tipo della variabile di intervallo, viene eseguito il cast di ogni elemento presente nell'oggetto ArrayList su un oggetto Student.

L'utilizzo di una variabile di intervallo tipizzata in modo esplicito in un'espressione di query equivale alla chiamata del metodo Cast<TResult>. Il metodo Cast<TResult> genera un'eccezione se non è possibile eseguire il cast specificato. Cast<TResult> e OfType<TResult> sono i due metodi di operatore query standard che agiscono sui tipi IEnumerable non generici. In Visual Basic è necessario chiamare in modo esplicito il metodo Cast<TResult> sull'origine dati per assicurare un tipo di variabile di intervallo specifico. Per ulteriori informazioni, vedereRelazioni tra i tipi nelle operazioni di query (Visual Basic) e Relazioni tra i tipi nelle operazioni di query LINQ (C#).

Esempio

Nell'esempio seguente viene illustrata una query semplice su un oggetto ArrayList. In questo esempio vengono utilizzati gli inizializzatori di oggetto quando il codice chiama il metodo Add, sebbene non sia un 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
*/

Vedere anche

Concetti

LINQ to Objects