Поделиться через


Практическое руководство. Выполнение запроса к ArrayList с помощью LINQ

При использовании LINQ для запросов к неуниверсальным IEnumerable коллекциям, например ArrayList, необходимо явным образом объявлять тип переменной диапазона, чтобы отразить конкретный тип объектов в коллекции. Например, если имеется ArrayList из объектов Student, предложение from (C#) или Предложение From (Visual Basic) должно выглядеть следующим образом.

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

При указании типа переменной диапазона каждый элемент в ArrayList приводится к Student.

Использование переменной диапазона с явно заданным типом в выражении запроса эквивалентно вызову метода Cast<TResult>. Метод Cast<TResult> вызывает исключение, если не удается выполнить указанное приведение. Cast<TResult> и OfType<TResult> — это два метода стандартного оператора запроса, применяемые к неуниверсальным типам IEnumerable. В Visual Basic необходимо явно вызывать метод Cast<TResult> для источника данных, чтобы обеспечить конкретный тип переменной диапазона. Дополнительные сведения см. в разделах Отношения типов в операциях запроса (Visual Basic) и Отношения между типами в операциях запросов LINQ (C#).

Пример

В следующем примере показан простой запрос к ArrayList. Обратите внимание, что в этом примере при вызове кодом метода Add используются инициализаторы объектов, но это не является обязательным.

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

См. также

Основные понятия

LINQ to Objects