Como: consulta uma ArrayList com LINQ
Ao usar LINQ a consulta não genérica IEnumerable coleções, sistema autônomo ArrayList, você deve explicitamente declarar 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#) or A partir da cláusula (Visual Basic) deve ter esta aparência:
// 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, estão lançando cada item no ArrayList para um Student.
O uso de uma variável de intervalo explicitamente digitados 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> dois métodos de operador de consulta padrão que operam na não genérica IEnumerable tipos.
Exemplo
O exemplo a seguir mostra uma consulta simples em 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 FirstName As String
Public LastName As String
Public 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
*/