Поделиться через


Expression.Subtract Метод

Определение

Создает BinaryExpression, представляющий операцию арифметического вычитания, не содержащую проверку переполнения.

Перегрузки

Subtract(Expression, Expression)

Создает BinaryExpression, представляющий операцию арифметического вычитания, не содержащую проверку переполнения.

Subtract(Expression, Expression, MethodInfo)

Создает BinaryExpression, представляющий операцию арифметического вычитания, не содержащую проверку переполнения.

Subtract(Expression, Expression)

Исходный код:
BinaryExpression.cs
Исходный код:
BinaryExpression.cs
Исходный код:
BinaryExpression.cs

Создает BinaryExpression, представляющий операцию арифметического вычитания, не содержащую проверку переполнения.

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

Параметры

left
Expression

Объект Expression, который следует задать в качестве значения свойства Left.

right
Expression

Объект Expression, который следует задать в качестве значения свойства Right.

Возвращаемое значение

Выражение BinaryExpression со свойствомNodeType, равным Subtract, и свойствами Left и Right, для которых заданы указанные значения.

Исключения

Параметр left или right имеет значение null.

Оператор вычитания не определен для типов left.Type и right.Type.

Примеры

В следующем примере кода показано, как создать выражение, которое вычитает аргумент из первого аргумента.

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

Комментарии

Результирующее BinaryExpression свойство имеет Method значение реализующий метод. Свойству Type присваивается тип узла. Если узел приподнят, IsLifted свойства и IsLiftedToNull имеют значение true. В противном случае они имеют значение false. Значение свойства Conversionnull.

В следующих сведениях описывается реализующий метод, тип узла и возможность подъема узла.

Метод реализации

Следующие правила определяют выбранный метод реализации для операции:

  • Type Если свойство объекта left или right представляет определяемый пользователем тип, который перегружает оператор вычитания, то объект , MethodInfo представляющий этот метод, является реализующим методом.

  • В противном случае , если left. Введите и right. Тип — это числовые типы, реализующим методом — null.

Тип узла, а также тип невозвыводимый и невозвыводимый

Если реализующим методом не nullявляется :

  • Если left. Введите и right. Тип можно назначить соответствующим типам аргументов реализующего метода, узел не поднимается. Тип узла является типом возвращаемого значения реализующего метода.

  • Если выполняются следующие два условия, узел поднимается, а тип узла является типом, допускающим значение NULL, который соответствует типу возвращаемого значения реализующего метода:

    • left. Введите и right. Тип — это оба типа значений, по крайней мере один из которых допускает значение NULL, а соответствующие типы, не допускающие значения NULL, равны соответствующим типам аргументов реализующего метода.

    • Тип возвращаемого значения реализующего метода является типом значения, не допускающим значение NULL.

Если реализующим методом является null:

  • Если left. Введите и right. Тип не допускает значения NULL, узел не поднимается. Тип узла — это тип результата предопределенного оператора вычитания.

  • Если left. Введите и right. Тип допускает значение NULL, узел поднимается. Тип узла — это тип, допускающий значение NULL, соответствующий типу результата предопределенного оператора вычитания.

Применяется к

Subtract(Expression, Expression, MethodInfo)

Исходный код:
BinaryExpression.cs
Исходный код:
BinaryExpression.cs
Исходный код:
BinaryExpression.cs

Создает BinaryExpression, представляющий операцию арифметического вычитания, не содержащую проверку переполнения.

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

Параметры

left
Expression

Объект Expression, который следует задать в качестве значения свойства Left.

right
Expression

Объект Expression, который следует задать в качестве значения свойства Right.

method
MethodInfo

Объект MethodInfo, который следует задать в качестве значения свойства Method.

Возвращаемое значение

Выражение BinaryExpression со свойством NodeType, равным Subtract, и свойствами Left, Right и Method, для которых заданы указанные значения.

Исключения

Параметр left или right имеет значение null.

method не имеет значение null, и метод, который он представляет, возвращает void, а не static (Shared в Visual Basic), или не принимает ровно два аргумента.

method имеет значение null, и оператор вычитания не определен для left.Type и right.Type.

Комментарии

Результирующее BinaryExpression свойство имеет Method значение реализующий метод. Свойству Type присваивается тип узла. Если узел приподнят, IsLifted свойства и IsLiftedToNull имеют значение true. В противном случае они имеют значение false. Значение свойства Conversionnull.

В следующих сведениях описывается реализующий метод, тип узла и возможность подъема узла.

Метод реализации

Следующие правила определяют метод реализации операции:

  • Если method не является null и представляет метод non-void ( staticShared в Visual Basic), который принимает два аргумента, это реализующий метод для узла.

  • В противном случае, если Type свойство или leftright представляет определяемый пользователем тип, который перегружает оператор вычитания, объект , MethodInfo представляющий этот метод, является методом реализации.

  • В противном случае , если left. Введите и right. Тип — это числовые типы, реализующим методом — null.

Тип узла, а также тип невозвыводимый и невозвыводимый

Если реализующим методом не nullявляется :

  • Если left. Введите и right. Тип можно назначить соответствующим типам аргументов реализующего метода, узел не поднимается. Тип узла является типом возвращаемого значения реализующего метода.

  • Если выполняются следующие два условия, узел поднимается, а тип узла является типом, допускающим значение NULL, который соответствует типу возвращаемого значения реализующего метода:

    • left. Введите и right. Тип — это оба типа значений, по крайней мере один из которых допускает значение NULL, а соответствующие типы, не допускающие значения NULL, равны соответствующим типам аргументов реализующего метода.

    • Тип возвращаемого значения реализующего метода является типом значения, не допускающим значение NULL.

Если реализующим методом является null:

  • Если left. Введите и right. Тип не допускает значения NULL, узел не поднимается. Тип узла — это тип результата предопределенного оператора вычитания.

  • Если left. Введите и right. Тип допускает значение NULL, узел поднимается. Тип узла — это тип, допускающий значение NULL, соответствующий типу результата предопределенного оператора вычитания.

Применяется к