Porady: zapytanie w ArrayList za pomocą LINQ

Podczas korzystania z LINQ do rodzajowy kwerendy IEnumerable kolekcje, takich jak ArrayList, należy jawnie zadeklarować typ zmiennej zakres, aby odzwierciedlić określonego typu obiektów w kolekcji.Na przykład, jeśli masz ArrayList z Student obiektów, na z klauzuli (C#) lub From — Klauzula (Visual Basic) powinna wyglądać następująco:

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

Określając typ zmiennej zakres są rzutowanie każdego elementu w ArrayList do Student.

Użycie zmiennej zakres jawnie wpisywanych w wyrażeniu kwerendy jest odpowiednikiem telefonicznej Cast``1 metody.Cast``1Jeśli nie można wykonać określone rzutowanie, zgłasza wyjątek.Cast``1i OfType``1 są dwie metody standardowego operatora kwerendy, które operują na nierodzajową IEnumerable typów.W Visual Basic, należy jawnie wywołać Cast``1 metody na źródła danych w celu zapewnienia typu zmiennej określonego zakresu.Aby uzyskać więcej informacji, zobaczRelacje typu w operacjach zapytań (Visual Basic) i Relacje typu w operacjach kwerend LINQ (C#).

Przykład

W poniższym przykładzie pokazano prostą kwerendę nad ArrayList.Uwaga w tym przykładzie użyto obiektu inicjatorów, gdy kod wywołuje Add metody, ale nie jest to wymagane.

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
*/

Zobacz też

Koncepcje

LINQ do obiektów