Sdílet prostřednictvím


Postupy: Vytvoření dotazu na ArrayList pomocí LINQ

Při použití LINQ k dotazu Obecné IEnumerable kolekce jako ArrayList, musí explicitně deklarovat typ proměnné rozsah podle určitého typu objektů v kolekci.Pokud máte například ArrayList z Student objekty, vaše klauzule from (C#) nebo From – klauzule (Visual Basic) by měl vypadat takto:

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

Určením typu proměnné rozsah jsou obsazení jednotlivých položek v ArrayList se Student.

Použití explicitně zadaný rozsah proměnné ve výrazu dotazu je ekvivalentní volací Cast``1 metoda.Cast``1Pokud nelze provést určené přetypování vyvolá výjimku.Cast``1a OfType``1 jsou dvě metody standardní operátor dotazu, které fungují na Obecné IEnumerable typy.V Visual Basic, explicitně volat Cast``1 metodu na zdroj dat pro zajištění určitého rozsahu proměnné typu.Další informace naleznete vVztahy typů v operacích dotazu (Visual Basic) a Vztahy typů v operacích dotazu LINQ (C#).

Příklad

Následující příklad ukazuje jednoduchý dotaz nad ArrayList.Poznámka, že tento příklad používá objekt Inicializátory když kód volá Add metoda, ale to není vyžadováno.

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

Viz také

Koncepty

LINQ na objekty