Dieser Artikel wurde maschinell übersetzt. Wenn Sie die englische Version des Artikels anzeigen möchten, aktivieren Sie das Kontrollkästchen Englisch. Sie können den englischen Text auch in einem Popupfenster anzeigen, indem Sie den Mauszeiger über den Text bewegen.
Übersetzung
Englisch

Expression.Subtract-Methode: (Expression, Expression)

 

Veröffentlicht: Oktober 2016

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

Namespace:   System.Linq.Expressions
Assembly:  System.Core (in System.Core.dll)

public static BinaryExpression Subtract(
	Expression left,
	Expression right
)

Parameter

left
Type: System.Linq.Expressions.Expression

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

right
Type: System.Linq.Expressions.Expression

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

Rückgabewert

Type: System.Linq.Expressions.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.

Exception Condition
ArgumentNullException

left oder right ist null.

InvalidOperationException

Der Subtraktionsoperator ist nicht definiert left. Typ und right. Geben Sie ein.

Das resultierende BinaryExpression hat die Method -Eigenschaft auf die implementierende Methode festgelegt. Die Type -Eigenschaft auf den Typ des Knotens festgelegt ist. Wenn der Knoten transformiert wird, die IsLifted und IsLiftedToNull Eigenschaften sind beide true. Andernfalls sind sie false. Die Conversion-Eigenschaft ist null.

Die folgenden Informationen beschreiben die implementierende Methode und der Knotentyp und, ob ein Knoten transformiert wird.

Die folgenden Regeln bestimmen die ausgewählte implementierende Methode für den Vorgang.

  • Wenn die Type -Eigenschaft von left oder right einen benutzerdefinierten Typ darstellt, der den Subtraktionsoperator überlädt die MethodInfo die Methode darstellt, die implementierende Methode.

  • Andernfalls gilt: Wenn left. Typ und right. Type numerische Typen, die die implementierende Methode null.

Die implementierende Methode ist nicht null:

  • Wenn left. Typ und right. Geben den entsprechenden Argumenttypen der implementierenden Methode zugeordnet werden können, ist der Knoten nicht transformiert. Der Typ des Knotens ist der Rückgabetyp der implementierenden Methode.

  • Wenn die beiden folgenden Bedingungen erfüllt sind, ist der Knoten transformiert und des Typs des Knotens Nullable-Typs, der in den Rückgabetyp der implementierenden Methode entspricht:

    • left. Typ und right. Sind beide Werttypen, von denen mindestens NULL ist zulässig, und die entsprechenden NULL-Typen sind gleich den entsprechenden Argumenttypen der implementierenden Methode.

    • Der Rückgabetyp der implementierenden Methode ist ein NULL-Wert.

Wenn die implementierende Methode null:

  • Wenn left. Typ und right. Sind NULL-Werte zulassen, der Knoten nicht transformiert. Der Typ des Knotens ist der Ergebnistyp des vordefinierten Subtraktionsoperators.

  • Wenn left. Typ und right. Sind NULL-Werte zulassen, der Knoten transformiert wird. Der Typ des Knotens ist Nullable-Typs, der dem Ergebnistyp des vordefinierten Subtraktionsoperators entspricht.

Im folgenden Codebeispiel wird veranschaulicht, wie einen Ausdruck erstellt, der das Argument vom ersten Argument subtrahiert wird.

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

Universelle Windows-Plattform
Verfügbar seit 8
.NET Framework
Verfügbar seit 3.5
Portierbare Klassenbibliothek
Unterstützt in: portierbare .NET-Plattformen
Silverlight
Verfügbar seit 2.0
Windows Phone Silverlight
Verfügbar seit 7.0
Windows Phone
Verfügbar seit 8.1
Zurück zum Anfang
Anzeigen: