Conversão de tipos de dados (Visual Basic)
Os métodos de conversão alteram o tipo dos objetos de entrada.
As operações de conversão em consultas LINQ são úteis em diversas aplicações. Estes são alguns exemplos:
O método Enumerable.AsEnumerable pode ser usado para ocultar a implementação personalizada de um tipo de um operador de consulta padrão.
O método Enumerable.OfType pode ser usado para habilitar coleções sem parâmetros para consulta LINQ.
Os métodos Enumerable.ToArray, Enumerable.ToDictionary, Enumerable.ToList e Enumerable.ToLookup podem ser usados para forçar a execução de consulta imediata em vez de adiá-la até que a consulta seja enumerada.
Métodos
A tabela a seguir lista os métodos de operador de consulta padrão que realizam conversões de tipo de dados.
Os métodos de conversão nesta tabela cujos nomes começam com "As" alteram o tipo estático da coleção de origem, mas não a enumeram. Os métodos cujos nomes começam com "To" enumeram a coleção de origem e colocam os itens na coleção de tipo correspondente.
Nome do método | Descrição | Sintaxe da Expressão de Consulta do Visual Basic | Mais informações |
---|---|---|---|
AsEnumerable | Retorna a entrada digitada como IEnumerable<T>. | Não aplicável. | Enumerable.AsEnumerable |
AsQueryable | Converte um IEnumerable (genérico) em um IQueryable (genérico). | Não aplicável. | Queryable.AsQueryable |
Conversão | Converte os elementos de uma coleção em um tipo especificado. | From … As … |
Enumerable.Cast Queryable.Cast |
OfType | Filtra valores, dependendo da capacidade de serem convertidos em um tipo especificado. | Não aplicável. | Enumerable.OfType Queryable.OfType |
ToArray | Converte uma coleção em uma matriz. Esse método força a execução de consulta. | Não aplicável. | Enumerable.ToArray |
ToDictionary | Coloca os elementos em um Dictionary<TKey,TValue> com base em uma função de seletor de chave. Esse método força a execução de consulta. | Não aplicável. | Enumerable.ToDictionary |
ToList | Converte uma coleção em um List<T>. Esse método força a execução de consulta. | Não aplicável. | Enumerable.ToList |
ToLookup | Coloca os elementos em um Lookup<TKey,TElement> (um dicionário one-to-many) com base em uma função de seletor de chave. Esse método força a execução de consulta. | Não aplicável. | Enumerable.ToLookup |
Exemplo de sintaxe de expressão de consulta
O exemplo de código a seguir usa a cláusula From As
para converter um tipo em um subtipo antes de acessar um membro que está disponível somente no subtipo.
Class Plant
Public Property Name As String
End Class
Class CarnivorousPlant
Inherits Plant
Public Property TrapType As String
End Class
Sub Cast()
Dim plants() As Plant = {
New CarnivorousPlant With {.Name = "Venus Fly Trap", .TrapType = "Snap Trap"},
New CarnivorousPlant With {.Name = "Pitcher Plant", .TrapType = "Pitfall Trap"},
New CarnivorousPlant With {.Name = "Sundew", .TrapType = "Flypaper Trap"},
New CarnivorousPlant With {.Name = "Waterwheel Plant", .TrapType = "Snap Trap"}}
Dim query = From plant As CarnivorousPlant In plants
Where plant.TrapType = "Snap Trap"
Select plant
Dim sb As New System.Text.StringBuilder()
For Each plant In query
sb.AppendLine(plant.Name)
Next
' Display the results.
MsgBox(sb.ToString())
' This code produces the following output:
' Venus Fly Trap
' Waterwheel Plant
End Sub