Partilhar via


Depurando LINQ

O Visual Studio oferece suporte à depuração de código LINQ (Language Integrated Query), com algumas limitações. A maioria dos recursos de depuração funciona com instruções LINQ, incluindo execução passo a passo, definição de pontos de interrupção e visualização de resultados nas janelas do depurador. Este tópico descreve as principais limitações da depuração LINQ.

Visualizando resultados do LINQ

Você pode exibir o resultado de uma instrução LINQ usando DataTips, a janela Watch e a caixa de diálogo QuickWatch. Quando usas uma janela de origem, podes parar o ponteiro sobre uma consulta na janela de origem e um DataTip surgirá. Você pode copiar uma variável LINQ e colá-la na janela Watch ou na caixa de diálogo QuickWatch.

No LINQ, uma consulta não é avaliada quando é criada ou declarada, mas apenas quando a consulta é usada. Portanto, a consulta não tem um valor até que seja avaliada. Para obter uma descrição completa da criação e avaliação de consultas, consulte Introdução às consultas LINQ (C#) ou Escrevendo sua primeira consulta LINQ.

Para exibir o resultado de uma consulta, o depurador deve avaliá-lo. Essa avaliação implícita, que ocorre quando você visualiza um resultado de consulta LINQ no depurador, tem alguns efeitos que você deve considerar:

  • Cada avaliação da consulta leva tempo. Expandir o nó de resultados leva tempo. Para algumas consultas, a avaliação repetida pode resultar em uma penalidade de desempenho percetível.

  • A avaliação de uma consulta pode resultar em efeitos colaterais, que são alterações no valor dos dados ou no estado do seu programa. Nem todas as consultas têm efeitos secundários. Para determinar se uma consulta pode ser avaliada com segurança sem efeitos colaterais, você deve entender o código que implementa a consulta.

Stepping e LINQ

Quando estás a depurar código LINQ, a execução passo a passo tem algumas diferenças comportamentais que deves conhecer.

LINQ para SQL

Em consultas LINQ to SQL, o código de predicado está fora do controle do depurador. Portanto, você não pode entrar no código de predicado. Qualquer consulta compilada em uma árvore de expressão produz código que está além do controle do depurador.

Interação passo a passo no Visual Basic

Quando você está passando por um programa do Visual Basic e o depurador encontra uma declaração de consulta, ele não entra na declaração, mas destaca a declaração inteira como uma única instrução. Esse comportamento ocorre porque a consulta não é avaliada até que seja chamada. Para obter mais informações, consulte Introdução ao LINQ no Visual Basic.

Se percorreres o código de exemplo a seguir, o depurador destacará a declaração de consulta, ou criação de consulta, como uma única declaração.

Function MyFunction(ByVal x As Char)
    Return True
End Function

Sub Main()
    'Query creation
    Dim x = From it In "faoaoeua" _
            Where MyFunction(it) _
            Select New With {.a = it}

    ' Query execution
    For Each cur In x
        Console.WriteLine(cur.ToString())
    Next
End Sub

Quando você pisa novamente, o depurador destaca For Each cur In x. No passo seguinte, chega à função MyFunction. Depois de passar por MyFunction, ele salta de volta para Console.WriteLine(cur.ToSting()). Em nenhum momento ele percorre o código de predicado na declaração da consulta, embora o depurador avalie esse código.

Substituindo um predicado por uma função para habilitar a execução passo a passo (Visual Basic)

Caso seja necessário percorrer o código de um predicado para fins de depuração, podes substituir o predicado por uma chamada para uma função que contenha o código do predicado original. Por exemplo, suponha que você tenha este código:

Dim items() as integer ={1, 2, 3, 4, 5, 6, 7, 8, 9, 10}

' Get the even numbers
Dim query = From nextInt in items Where nextInt Mod 2 = 0 Select nextInt

For each item in query
      Console.WriteLine(item)
Next

Você pode mover o código de predicado para uma nova função, chamada IsEven:

Dim items () as integer ={1, 2, 3, 4, 5, 6, 7, 8, 9, 10}

' Get the even numbers
Dim query = From nextInt in items Where IsEven(nextInt) Select nextInt

For each item in query
      Console.WriteLine(item)
Next
...
Function IsEven(item As =Integer) as Boolean
      Return item Mod 2 = 0
End Function

A consulta revisada chama a função IsEven em cada passagem pelo items. Você pode usar as janelas do depurador para ver se cada item atende à condição especificada e pode seguir o passo a passo do código em IsEven. O predicado neste exemplo é bastante simples. No entanto, se você tem um predicado mais difícil que você tem que depurar, esta técnica pode ser muito útil.

Editar e continuar não suportado para LINQ

Editar e Continuar suporta alterações em consultas LINQ com limitações. Para detalhes, consulte Alterações Suportadas pelo EnC