Expression.Subtract Methode

Definition

Erstellt eine BinaryExpression, die eine arithmetische Subtraktion ohne Überlaufprüfung darstellt.

Überlädt

Subtract(Expression, Expression)

Erstellt eine BinaryExpression, die eine arithmetische Subtraktion ohne Überlaufprüfung darstellt.

Subtract(Expression, Expression, MethodInfo)

Erstellt eine BinaryExpression, die eine arithmetische Subtraktion ohne Überlaufprüfung darstellt.

Subtract(Expression, Expression)

Erstellt eine BinaryExpression, die eine arithmetische Subtraktion ohne Überlaufprüfung darstellt.

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

Parameter

left
Expression

Ein Expression, auf den die Left-Eigenschaft festgelegt werden soll.

right
Expression

Ein Expression, auf das die Right-Eigenschaft festgelegt werden soll.

Gibt zurück

BinaryExpression

Ein BinaryExpression, bei dem die NodeType-Eigenschaft gleich Subtract ist und die Left-Eigenschaft sowie die Right-Eigenschaft auf die angegebenen Werte festgelegt sind.

Ausnahmen

left oder right ist null.

Der Subtraktionsoperator ist für left.Type und right.Type nicht definiert.

Beispiele

Im folgenden Codebeispiel wird gezeigt, wie Sie einen Ausdruck erstellen, der das Argument vom ersten Argument subtrahiert.

// 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

Hinweise

Das ergebnis BinaryExpression hat die Eigenschaft auf die Method Implementierungsmethode festgelegt. Die Type Eigenschaft wird auf den Typ des Knotens festgelegt. Wenn der Knoten aufgehoben wird, sind die IsLifted IsLiftedToNull eigenschaften beide true. Andernfalls sind falsesie . Die Conversion-Eigenschaft ist null.

Die folgenden Informationen beschreiben die Implementierungsmethode, den Knotentyp und ob ein Knoten aufgehoben wird.

Implementierungsmethode

Die folgenden Regeln bestimmen die ausgewählte Implementierungsmethode für den Vorgang:

  • Wenn die Type Eigenschaft eines left right oder eines benutzerdefinierten Typs darstellt, der den Subtraktionsoperator überlastet, MethodInfo ist diese Methode die Implementierungsmethode.

  • Andernfalls, wenn left. Typ und right. Typ sind numerische Typen, die Implementierungsmethode ist null.

Knotentyp und Aufgehoben im Vergleich zu nicht aufgehobenen Knotentypen

Wenn die Implementierungsmethode nicht null:

  • Wenn left. Typ und right. Der Typ kann den entsprechenden Argumenttypen der Implementierungsmethode zugewiesen werden, der Knoten wird nicht aufgehoben. Der Typ des Knotens ist der Rückgabetyp der Implementierungsmethode.

  • Wenn die folgenden beiden Bedingungen erfüllt sind, wird der Knoten aufgehoben und der Typ des Knotens ist der nullfähige Typ, der dem Rückgabetyp der Implementierungsmethode entspricht:

    • left. Typ und right. Der Typ ist beide Werttypen, von denen mindestens eine nullwertig ist, und die entsprechenden nicht nullablen Typen entsprechen den entsprechenden Argumenttypen der Implementierungsmethode.

    • Der Rückgabetyp der Implementierungsmethode ist ein nicht nullabler Werttyp.

Wenn die Implementierungsmethode null:

  • Wenn left. Typ und right. Der Typ ist nicht nullierbar, der Knoten wird nicht aufgehoben. Der Typ des Knotens ist der Ergebnistyp des vordefinierten Subtraktionsoperators.

  • Wenn left. Typ und right. Der Typ ist beide nullwertig, der Knoten wird aufgehoben. Der Typ des Knotens ist der nullable Typ, der dem Ergebnistyp des vordefinierten Subtraktionsoperators entspricht.

Gilt für

Subtract(Expression, Expression, MethodInfo)

Erstellt eine BinaryExpression, die eine arithmetische Subtraktion ohne Überlaufprüfung darstellt.

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

Parameter

left
Expression

Ein Expression, auf das die Left-Eigenschaft festgelegt werden soll.

right
Expression

Ein Expression, auf das die Right-Eigenschaft festgelegt werden soll.

method
MethodInfo

Ein MethodInfo, auf das die Method-Eigenschaft festgelegt werden soll.

Gibt zurück

BinaryExpression

Ein BinaryExpression, bei dem die NodeType-Eigenschaft gleich Subtract ist und die Eigenschaften Left, Right und Method auf die angegebenen Werte festgelegt sind.

Ausnahmen

left oder right ist null.

method ist nicht null, und die dargestellte Methode gibt void zurück, ist nicht static (Shared in Visual Basic) oder akzeptiert nicht genau zwei Argumente.

method ist null, und der Subtraktionsoperator ist für left.Type und right.Type nicht definiert.

Hinweise

Das ergebnis BinaryExpression hat die Eigenschaft auf die Method Implementierungsmethode festgelegt. Die Type Eigenschaft wird auf den Typ des Knotens festgelegt. Wenn der Knoten aufgehoben wird, sind die IsLifted IsLiftedToNull eigenschaften beide true. Andernfalls sind falsesie . Die Conversion-Eigenschaft ist null.

Die folgenden Informationen beschreiben die Implementierungsmethode, den Knotentyp und ob ein Knoten aufgehoben wird.

Implementierungsmethode

Die folgenden Regeln bestimmen die Implementierungsmethode für den Vorgang:

  • Wenn method nicht null und stellt eine nicht ungültige, (Shared in Visual Basic) -Methode dar, die zwei Argumente verwendet, static ist es die Implementierungsmethode für den Knoten.

  • Andernfalls ist die Type Eigenschaft eines left right oder eines benutzerdefinierten Typs dargestellt, der den Subtraktionsoperator überlastet, der MethodInfo diese Methode darstellt, die die Implementierungsmethode darstellt.

  • Andernfalls, wenn left. Typ und right. Typ sind numerische Typen, die Implementierungsmethode ist null.

Knotentyp und Aufgehoben im Vergleich zu nicht aufgehobenen Knotentypen

Wenn die Implementierungsmethode nicht null:

  • Wenn left. Typ und right. Der Typ kann den entsprechenden Argumenttypen der Implementierungsmethode zugewiesen werden, der Knoten wird nicht aufgehoben. Der Typ des Knotens ist der Rückgabetyp der Implementierungsmethode.

  • Wenn die folgenden beiden Bedingungen erfüllt sind, wird der Knoten aufgehoben und der Typ des Knotens ist der nullfähige Typ, der dem Rückgabetyp der Implementierungsmethode entspricht:

    • left. Typ und right. Der Typ ist beide Werttypen, von denen mindestens eine nullwertig ist, und die entsprechenden nicht nullablen Typen entsprechen den entsprechenden Argumenttypen der Implementierungsmethode.

    • Der Rückgabetyp der Implementierungsmethode ist ein nicht nullabler Werttyp.

Wenn die Implementierungsmethode lautet null:

  • Wenn left. Typ und right. Der Typ ist nicht nullfähig, der Knoten wird nicht aufgehoben. Der Typ des Knotens ist der Ergebnistyp des vordefinierten Subtraktionsoperators.

  • Wenn left. Typ und right. Der Typ ist beide nullfähig, der Knoten wird aufgehoben. Der Typ des Knotens ist der nullfähige Typ, der dem Ergebnistyp des vordefinierten Subtraktionsoperators entspricht.

Gilt für