Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Quando si usa LINQ per eseguire query su raccolte non generiche IEnumerable , ad ArrayListesempio , è necessario dichiarare in modo esplicito il tipo della variabile di intervallo in modo da riflettere il tipo specifico degli oggetti nell'insieme. Ad esempio, se si dispone di un ArrayList di Student oggetti, la Clausola From dovrebbe essere simile alla seguente:
Dim query = From student As Student In arrList
'...
Specificando il tipo della variabile di intervallo, si esegue il cast di ogni elemento nell'oggetto ArrayList a un oggetto Student.
L'uso di una variabile di intervallo tipizzata in modo esplicito in un'espressione di query equivale a chiamare il Cast metodo . Cast genera un'eccezione se non è possibile eseguire il cast specificato. Cast e OfType sono i due metodi Standard Query Operator che operano su tipi non generici IEnumerable. In Visual Basic è necessario chiamare in modo esplicito il Cast metodo sull'origine dati per garantire un tipo di variabile di intervallo specifico. Per altre informazioni, vedere Relazioni tra tipi nelle operazioni di query (Visual Basic).For more information, see Type Relationships in Query Operations (Visual Basic).
Esempio
Nell'esempio seguente viene illustrata una query semplice su un oggetto ArrayList. Si noti che questo esempio usa gli inizializzatori di oggetto quando il codice chiama il Add metodo , ma questo non è 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