Expression.Subtract Méthode

Définition

Crée un BinaryExpression qui représente une opération de soustraction arithmétique qui ne dispose pas d'une vérification de dépassement de capacité.

Surcharges

Subtract(Expression, Expression)

Crée un BinaryExpression qui représente une opération de soustraction arithmétique qui ne dispose pas d'une vérification de dépassement de capacité.

Subtract(Expression, Expression, MethodInfo)

Crée un BinaryExpression qui représente une opération de soustraction arithmétique qui ne dispose pas d'une vérification de dépassement de capacité.

Subtract(Expression, Expression)

Crée un BinaryExpression qui représente une opération de soustraction arithmétique qui ne dispose pas d'une vérification de dépassement de capacité.

public:
 static System::Linq::Expressions::BinaryExpression ^ Subtract(System::Linq::Expressions::Expression ^ left, System::Linq::Expressions::Expression ^ right);
public static System.Linq.Expressions.BinaryExpression Subtract (System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right);
static member Subtract : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression -> System.Linq.Expressions.BinaryExpression
Public Shared Function Subtract (left As Expression, right As Expression) As BinaryExpression

Paramètres

left
Expression

Expression auquel la propriété Left doit être égale.

right
Expression

Expression auquel la propriété Right doit être égale.

Retours

BinaryExpression

BinaryExpression dont la propriété NodeType est égale à Subtract et dont les propriétés Left et Right ont les valeurs spécifiées.

Exceptions

left ou right est null.

L'opérateur de soustraction n'est pas défini pour left.Type et right.Type.

Exemples

L’exemple de code suivant montre comment créer une expression qui soustrait l’argument du premier argument.

// Add the following directive to your file:
// using System.Linq.Expressions;

// This expression subtracts the second argument
// from the first argument.
// Both arguments must be of the same type.
Expression subtractExpr = Expression.Subtract(
    Expression.Constant(12),
    Expression.Constant(3)
);

// Print out the expression.
Console.WriteLine(subtractExpr.ToString());

// The following statement first creates an expression tree,
// then compiles it, and then executes it.
Console.WriteLine(Expression.Lambda<Func<int>>(subtractExpr).Compile().Invoke());

// This code example produces the following output:
//
// (12 - 3)
// 9
' Add the following directive to your file:
' Imports System.Linq.Expressions  

' This expression subtracts the second argument 
' from the first argument.
' Both arguments must be of the same type.
Dim subtractExpr As Expression = Expression.Subtract(
     Expression.Constant(12),
     Expression.Constant(3)
 )

' Print the expression.
Console.WriteLine(subtractExpr.ToString())

' The following statement first creates an expression tree,
' then compiles it, and then executes it.            
Console.WriteLine(Expression.Lambda(Of Func(Of Integer))(subtractExpr).Compile()())

' This code example produces the following output:
'
' (12 - 3)
' 9

Remarques

Le résultat BinaryExpression a la Method propriété définie sur la méthode d’implémentation. La Type propriété est définie sur le type du nœud. Si le nœud est levé, les propriétés et IsLiftedToNull les IsLifted propriétés sont à la fois true. Sinon, ils sont false. La propriété Conversion a la valeur null.

Les informations suivantes décrivent la méthode d’implémentation, le type de nœud et si un nœud est levé.

Implémentation de la méthode

Les règles suivantes déterminent la méthode d’implémentation sélectionnée pour l’opération :

  • Si la propriété de l’un Type ou right l’autre left représente un type défini par l’utilisateur qui surcharge l’opérateur de soustraction, celle MethodInfo qui représente cette méthode est la méthode d’implémentation.

  • Sinon, si left. Tapez et right. Le type est des types numériques, la méthode d’implémentation est null.

Type de nœud et lifted versus non-lifted

Si la méthode d’implémentation n’est pas null:

  • Si left. Tapez et right. Le type est assignable aux types d’arguments correspondants de la méthode d’implémentation, le nœud n’est pas levé. Le type du nœud est le type de retour de la méthode d’implémentation.

  • Si les deux conditions suivantes sont remplies, le nœud est levé et le type du nœud est le type nullable qui correspond au type de retour de la méthode d’implémentation :

    • left. Tapez et right. Le type est les deux types de valeur dont au moins un est nullable et les types non nullables correspondants sont égaux aux types d’argument correspondants de la méthode d’implémentation.

    • Le type de retour de la méthode d’implémentation est un type de valeur non nullable.

Si la méthode d’implémentation est null:

  • Si left. Tapez et right. Le type n’est pas nullable, le nœud n’est pas levé. Le type du nœud est le type de résultat de l’opérateur de soustraction prédéfini.

  • Si left. Tapez et right. Le type est à la fois nullable, le nœud est levé. Le type du nœud est le type nullable qui correspond au type de résultat de l’opérateur de soustraction prédéfini.

S’applique à

Subtract(Expression, Expression, MethodInfo)

Crée un BinaryExpression qui représente une opération de soustraction arithmétique qui ne dispose pas d'une vérification de dépassement de capacité.

public:
 static System::Linq::Expressions::BinaryExpression ^ Subtract(System::Linq::Expressions::Expression ^ left, System::Linq::Expressions::Expression ^ right, System::Reflection::MethodInfo ^ method);
public static System.Linq.Expressions.BinaryExpression Subtract (System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right, System.Reflection.MethodInfo method);
public static System.Linq.Expressions.BinaryExpression Subtract (System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right, System.Reflection.MethodInfo? method);
static member Subtract : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression * System.Reflection.MethodInfo -> System.Linq.Expressions.BinaryExpression
Public Shared Function Subtract (left As Expression, right As Expression, method As MethodInfo) As BinaryExpression

Paramètres

left
Expression

Expression auquel la propriété Left doit être égale.

right
Expression

Expression auquel la propriété Right doit être égale.

method
MethodInfo

MethodInfo auquel la propriété Method doit être égale.

Retours

BinaryExpression

BinaryExpression dont la propriété NodeType est égale à Subtract et dont les propriétés Left, Right et Method ont les valeurs spécifiées.

Exceptions

left ou right est null.

method n’est pas null et la méthode représentée retourne void, pas static (Shared dans Visual Basic) ou ne prend pas exactement deux arguments.

method est null et l’opérateur de soustraction n’est pas défini pour left.Type et right.Type.

Remarques

Le résultat BinaryExpression a la Method propriété définie sur la méthode d’implémentation. La Type propriété est définie sur le type du nœud. Si le nœud est levé, les propriétés et IsLiftedToNull les IsLifted propriétés sont à la fois true. Sinon, ils sont false. La propriété Conversion a la valeur null.

Les informations suivantes décrivent la méthode d’implémentation, le type de nœud et si un nœud est levé.

Implémentation de la méthode

Les règles suivantes déterminent la méthode d’implémentation de l’opération :

  • Si method ce n’est pas null le cas et qu’il représente un non-void, static (Shareddans Visual Basic) qui accepte deux arguments, il s’agit de la méthode d’implémentation du nœud.

  • Sinon, si la propriété de l’un Type ou right l’autre left représente un type défini par l’utilisateur qui surcharge l’opérateur de soustraction, celui MethodInfo qui représente cette méthode est la méthode d’implémentation.

  • Sinon, si left. Tapez et right. Le type est des types numériques, la méthode d’implémentation est null.

Type de nœud et lifted versus non-lifted

Si la méthode d’implémentation n’est pas null:

  • Si left. Tapez et right. Le type est assignable aux types d’arguments correspondants de la méthode d’implémentation, le nœud n’est pas levé. Le type du nœud est le type de retour de la méthode d’implémentation.

  • Si les deux conditions suivantes sont remplies, le nœud est levé et le type du nœud est le type nullable qui correspond au type de retour de la méthode d’implémentation :

    • left. Tapez et right. Le type est les deux types de valeur dont au moins un est nullable et les types non nullables correspondants sont égaux aux types d’argument correspondants de la méthode d’implémentation.

    • Le type de retour de la méthode d’implémentation est un type de valeur non nullable.

Si la méthode d’implémentation est null:

  • Si left. Tapez et right. Le type n’est pas nullable, le nœud n’est pas levé. Le type du nœud est le type de résultat de l’opérateur de soustraction prédéfini.

  • Si left. Tapez et right. Le type est à la fois nullable, le nœud est levé. Le type du nœud est le type Nullable qui correspond au type de résultat de l’opérateur de soustraction prédéfini.

S’applique à