Nota
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
En este tema se muestra cómo modificar un árbol de expresiones. Los árboles de expresión son inmutables, lo que significa que no se pueden modificar directamente. Para cambiar un árbol de expresión, debe crear una copia de un árbol de expresiones existente y, al crear la copia, realizar los cambios necesarios. Puede usar la ExpressionVisitor clase para recorrer un árbol de expresiones existente y copiar cada nodo que visita.
Para modificar un árbol de expresiones
Cree un nuevo proyecto de aplicación de consola .
Agregue una instrucción
Imports
al archivo para el espacio de nombresSystem.Linq.Expressions
.Agregue la
AndAlsoModifier
clase al proyecto.Public Class AndAlsoModifier Inherits ExpressionVisitor Public Function Modify(ByVal expr As Expression) As Expression Return Visit(expr) End Function Protected Overrides Function VisitBinary(ByVal b As BinaryExpression) As Expression If b.NodeType = ExpressionType.AndAlso Then Dim left = Me.Visit(b.Left) Dim right = Me.Visit(b.Right) ' Make this binary expression an OrElse operation instead ' of an AndAlso operation. Return Expression.MakeBinary(ExpressionType.OrElse, left, right, _ b.IsLiftedToNull, b.Method) End If Return MyBase.VisitBinary(b) End Function End Class
Esta clase hereda la ExpressionVisitor clase y está especializada en modificar expresiones que representan operaciones condicionales
AND
. Cambia estas operaciones de un condicionalAND
a un condicionalOR
. Para ello, la clase invalida el VisitBinary método del tipo base, ya que las expresiones condicionalesAND
se representan como expresiones binarias. En elVisitBinary
método , si la expresión que se pasa a ella representa una operación condicionalAND
, el código construye una nueva expresión que contiene el operador condicionalOR
en lugar del operador condicionalAND
. Si la expresión que se pasa aVisitBinary
no representa una operación condicionalAND
, el método se remite a la implementación de la clase base. Los métodos de clase base construyen nodos que son como los árboles de expresiones que se pasan, pero los subárboles de los nodos se reemplazan por los árboles de expresiones que genera de forma recursiva el visitante.Agregue una instrucción
Imports
al archivo para el espacio de nombresSystem.Linq.Expressions
.Agregue código al
Main
método en el archivo Module1.vb para crear un árbol de expresiones y pasarlo al método que lo modificará.Dim expr As Expression(Of Func(Of String, Boolean)) = _ Function(name) name.Length > 10 AndAlso name.StartsWith("G") Console.WriteLine(expr) Dim modifier As New AndAlsoModifier() Dim modifiedExpr = modifier.Modify(CType(expr, Expression)) Console.WriteLine(modifiedExpr) ' This code produces the following output: ' name => ((name.Length > 10) && name.StartsWith("G")) ' name => ((name.Length > 10) || name.StartsWith("G"))
El código crea una expresión que contiene una operación condicional
AND
. A continuación, crea una instancia de laAndAlsoModifier
clase y pasa la expresión alModify
método de esta clase. Tanto los árboles de expresión originales como los modificados se generan para mostrar el cambio.Compile y ejecute la aplicación.