Expression<TDelegate> Classe
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Représente une expression lambda fortement typée sous la forme d’une arborescence d’expressions. Cette classe ne peut pas être héritée.
generic <typename TDelegate>
public ref class Expression sealed : System::Linq::Expressions::LambdaExpression
public sealed class Expression<TDelegate> : System.Linq.Expressions.LambdaExpression
type Expression<'Delegate> = class
inherit LambdaExpression
Public NotInheritable Class Expression(Of TDelegate)
Inherits LambdaExpression
Paramètres de type
- TDelegate
Type du délégué que représente Expression<TDelegate> .
- Héritage
Exemples
L’exemple de code suivant montre comment représenter une expression lambda en tant que code exécutable sous la forme d’un délégué et en tant que données sous la forme d’une arborescence d’expressions. Il montre également comment réactiver l’arborescence d’expressions en code exécutable à l’aide de la Compile méthode.
// Lambda expression as executable code.
Func<int, bool> deleg = i => i < 5;
// Invoke the delegate and display the output.
Console.WriteLine("deleg(4) = {0}", deleg(4));
// Lambda expression as data in the form of an expression tree.
System.Linq.Expressions.Expression<Func<int, bool>> expr = i => i < 5;
// Compile the expression tree into executable code.
Func<int, bool> deleg2 = expr.Compile();
// Invoke the method and print the output.
Console.WriteLine("deleg2(4) = {0}", deleg2(4));
/* This code produces the following output:
deleg(4) = True
deleg2(4) = True
*/
' Lambda expression as executable code.
Dim deleg As Func(Of Integer, Boolean) = Function(ByVal i) i < 5
' Invoke the delegate and display the output.
MsgBox(String.Format("deleg(4) = {0}", deleg(4)))
' Lambda expression as data in the form of an expression tree.
Dim expr As System.Linq.Expressions.Expression(Of Func(Of Integer, Boolean)) = Function(ByVal i) i < 5
' Compile the expression tree into executable code.
Dim deleg2 As Func(Of Integer, Boolean) = expr.Compile()
' Invoke the method and print the output.
MsgBox(String.Format("deleg2(4) = {0}", deleg2(4)))
' This code produces the following output:
'
' deleg(4) = True
' deleg2(4) = True
Remarques
Lorsqu’une expression lambda est affectée à une variable, un champ ou un paramètre dont le type est Expression<TDelegate>, le compilateur émet des instructions pour générer une arborescence d’expressions.
Note
Une conversion d’une expression lambda en type Expression<D> (Expression(Of D) en Visual Basic) existe si une conversion de l’expression lambda en délégué de type D existe. Toutefois, la conversion peut échouer, par exemple, si le corps de l’expression lambda est un bloc. Cela signifie que les délégués et les arborescences d’expressions se comportent de la même façon en ce qui concerne la résolution de surcharge.
L’arborescence d’expressions est une représentation de données en mémoire de l’expression lambda. L’arborescence d’expressions rend la structure de l’expression lambda transparente et explicite. Vous pouvez interagir avec les données de l’arborescence d’expressions comme vous le pouvez avec n’importe quelle autre structure de données.
La possibilité de traiter les expressions en tant que structures de données permet aux API de recevoir du code utilisateur dans un format qui peut être inspecté, transformé et traité de manière personnalisée. Par exemple, l’implémentation d’accès aux données LINQ to SQL utilise cette fonctionnalité pour traduire des arborescences d’expressions en instructions Transact-SQL qui peuvent être évaluées par la base de données.
De nombreux opérateurs de requête standard définis dans la Queryable classe ont un ou plusieurs paramètres de type Expression<TDelegate>.
L’un NodeTypeExpression<TDelegate> est Lambda.
Utilisez la ou Lambda<TDelegate>(Expression, ParameterExpression[]) la Lambda<TDelegate>(Expression, IEnumerable<ParameterExpression>) méthode pour créer un Expression<TDelegate> objet.
Propriétés
| Nom | Description |
|---|---|
| Body |
Obtient le corps de l’expression lambda. (Hérité de LambdaExpression) |
| CanReduce |
Indique que le nœud peut être réduit à un nœud plus simple. Si cela retourne la valeur true, Reduce() peut être appelé pour produire le formulaire réduit. (Hérité de Expression) |
| Name |
Obtient le nom de l’expression lambda. (Hérité de LambdaExpression) |
| NodeType |
Retourne le type de nœud de ce Expression. (Hérité de LambdaExpression) |
| Parameters |
Obtient les paramètres de l’expression lambda. (Hérité de LambdaExpression) |
| ReturnType |
Obtient le type de retour de l’expression lambda. (Hérité de LambdaExpression) |
| TailCall |
Obtient la valeur qui indique si l’expression lambda sera compilée avec l’optimisation des appels de fin. (Hérité de LambdaExpression) |
| Type |
Obtient le type statique de l’expression que cela Expression représente. (Hérité de LambdaExpression) |
Méthodes
| Nom | Description |
|---|---|
| Accept(ExpressionVisitor) |
Répartit vers la méthode de visite spécifique pour ce type de nœud. Par exemple, MethodCallExpression appelle le VisitMethodCall(MethodCallExpression). (Hérité de Expression) |
| Compile() |
Compile l’expression lambda décrite par l’arborescence d’expressions en code exécutable et produit un délégué qui représente l’expression lambda. |
| Compile(Boolean) |
Compile l’expression lambda décrite par l’arborescence d’expressions en code interprété ou compilé et produit un délégué qui représente l’expression lambda. |
| Compile(DebugInfoGenerator) |
Produit un délégué qui représente l’expression lambda. |
| CompileToMethod(MethodBuilder, DebugInfoGenerator) |
Compile l’lambda dans une définition de méthode et des informations de débogage personnalisées. (Hérité de LambdaExpression) |
| CompileToMethod(MethodBuilder) |
Compile l’lambda dans une définition de méthode. (Hérité de LambdaExpression) |
| Equals(Object) |
Détermine si l’objet spécifié est égal à l’objet actuel. (Hérité de Object) |
| GetHashCode() |
Sert de fonction de hachage par défaut. (Hérité de Object) |
| GetType() |
Obtient la Type de l’instance actuelle. (Hérité de Object) |
| MemberwiseClone() |
Crée une copie superficielle du Objectactuel. (Hérité de Object) |
| Reduce() |
Réduit ce nœud à une expression plus simple. Si CanReduce retourne true, cela doit renvoyer une expression valide. Cette méthode peut retourner un autre nœud qui lui-même doit être réduit. (Hérité de Expression) |
| ReduceAndCheck() |
Réduit ce nœud à une expression plus simple. Si CanReduce retourne true, cela doit renvoyer une expression valide. Cette méthode peut retourner un autre nœud qui lui-même doit être réduit. (Hérité de Expression) |
| ReduceExtensions() |
Réduit l’expression à un type de nœud connu (qui n’est pas un nœud d’extension) ou retourne simplement l’expression s’il s’agit déjà d’un type connu. (Hérité de Expression) |
| ToString() |
Retourne une représentation textuelle du Expression. (Hérité de Expression) |
| Update(Expression, IEnumerable<ParameterExpression>) |
Crée une expression semblable à celle-ci, mais à l’aide des enfants fournis. Si tous les enfants sont identiques, il retourne cette expression. |
| VisitChildren(ExpressionVisitor) |
Réduit le nœud, puis appelle le délégué visiteur sur l’expression réduite. La méthode lève une exception si le nœud n’est pas réductible. (Hérité de Expression) |