Expression.Negate Метод

Определение

Создает UnaryExpression, представляющий операцию арифметического отрицания.Creates a UnaryExpression that represents an arithmetic negation operation.

Перегрузки

Negate(Expression, MethodInfo)

Создает UnaryExpression, представляющий операцию арифметического отрицания.Creates a UnaryExpression that represents an arithmetic negation operation.

Negate(Expression)

Создает UnaryExpression, представляющий операцию арифметического отрицания.Creates a UnaryExpression that represents an arithmetic negation operation.

Negate(Expression, MethodInfo)

Создает UnaryExpression, представляющий операцию арифметического отрицания.Creates a UnaryExpression that represents an arithmetic negation operation.

public:
 static System::Linq::Expressions::UnaryExpression ^ Negate(System::Linq::Expressions::Expression ^ expression, System::Reflection::MethodInfo ^ method);
public static System.Linq.Expressions.UnaryExpression Negate (System.Linq.Expressions.Expression expression, System.Reflection.MethodInfo method);
static member Negate : System.Linq.Expressions.Expression * System.Reflection.MethodInfo -> System.Linq.Expressions.UnaryExpression

Параметры

expression
Expression

Объект Expression, который следует задать в качестве значения свойства Operand.An Expression to set the Operand property equal to.

method
MethodInfo

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

Возвраты

Выражение UnaryExpression со свойствомNodeType, равным Negate, и свойствами Operand и Method, для которых заданы указанные значения.A UnaryExpression that has the NodeType property equal to Negate and the Operand and Method properties set to the specified values.

Исключения

Свойство expression имеет значение null.expression is null.

Значение параметра method не равно null, и метод, который представляется этим параметром, возвращает значение void, не является static (Shared в Visual Basic) и не принимает ровно один аргумент.method is not null and the method it represents returns void, is not static (Shared in Visual Basic), or does not take exactly one argument.

method равно null, а унарный минус-оператор не определен для типа expression.Type.method is null and the unary minus operator is not defined for expression.Type.

- или --or- Тип expression.Type (или соответствующий тип, не поддерживающий значение null, если он является типом, поддерживающим значение null) не назначается типу аргумента метода, представленного method.expression.Type (or its corresponding non-nullable type if it is a nullable value type) is not assignable to the argument type of the method represented by method.

Комментарии

Свойству полученного результата UnaryExpression присваивается метод реализации. MethodThe Method property of the resulting UnaryExpression is set to the implementing method. Для Type свойства задается тип узла.The Type property is set to the type of the node. Если узел ликвидируется, IsLifted свойства и IsLiftedToNull являются обоими true.If the node is lifted, the IsLifted and IsLiftedToNull properties are both true. В противном случае они имеют значение false.Otherwise, they are false.

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

Следующие правила определяют метод реализации для операции.The following rules determine the implementing method for the operation:

  • Если method static Shared параметр не равен ипредставляетметод,неявляющийсяvoid,(вVisualBasic),принимающийодинаргумент,тоэтореализующийметоддляузла.nullIf method is not null and it represents a non-void, static (Shared in Visual Basic) method that takes one argument, it is the implementing method for the node.

  • Если expression. Тип — это определяемый пользователем тип, определяющий унарный минус-оператор MethodInfo , который представляет этот оператор в качестве метода реализации.If expression.Type is a user-defined type that defines the unary minus operator, the MethodInfo that represents that operator is the implementing method.

  • В противном expressionслучае значение, если. Type является числовым типом, метод реализации — null.Otherwise, if expression.Type is a numeric type, the implementing method is null.

Тип узла и сравнение с нулификацией и без негоNode Type and Lifted versus Non-Lifted

Если метод реализации не nullимеет:If the implementing method is not null:

  • Если expression. Тип может быть назначен типу аргумента реализующего метода, узел не ликвидируется.If expression.Type is assignable to the argument type of the implementing method, the node is not lifted. Тип узла является типом возвращаемого значения метода реализации.The type of the node is the return type of the implementing method.

  • Если выполняются следующие два условия, узел ликвидируется, и тип узла является типом, допускающим значение null, который соответствует типу возвращаемого значения метода реализации:If the following two conditions are satisfied, the node is lifted and the type of the node is the nullable type that corresponds to the return type of the implementing method:

    • expression. Тип является типом значения, допускающим значение null, и соответствующий тип значения, не допускающий значения NULL, равен типу аргумента реализующего метода.expression.Type is a nullable value type and the corresponding non-nullable value type is equal to the argument type of the implementing method.

    • Возвращаемый тип метода реализации является типом значения, не допускающим значения NULL.The return type of the implementing method is a non-nullable value type.

Если метод реализации имеет значение null, тип узла —. expression Тип.If the implementing method is null, the type of the node is expression.Type. Если expression. Тип не допускает значения NULL, узел не ликвидируется.If expression.Type is non-nullable, the node is not lifted. В противном случае узел ликвидируется.Otherwise, the node is lifted.

Negate(Expression)

Создает UnaryExpression, представляющий операцию арифметического отрицания.Creates a UnaryExpression that represents an arithmetic negation operation.

public:
 static System::Linq::Expressions::UnaryExpression ^ Negate(System::Linq::Expressions::Expression ^ expression);
public static System.Linq.Expressions.UnaryExpression Negate (System.Linq.Expressions.Expression expression);
static member Negate : System.Linq.Expressions.Expression -> System.Linq.Expressions.UnaryExpression

Параметры

expression
Expression

Объект Expression, который следует задать в качестве значения свойства Operand.An Expression to set the Operand property equal to.

Возвраты

Выражение UnaryExpression со свойством NodeType, равным Negate, и свойством Operand, для которого задано указанное значение.A UnaryExpression that has the NodeType property equal to Negate and the Operand property set to the specified value.

Исключения

Свойство expression имеет значение null.expression is null.

Унарный минус-оператор не определен для типа expression.Type.The unary minus operator is not defined for expression.Type.

Примеры

В следующем примере показано, как создать выражение, представляющее операцию арифметического отрицания.The following example demonstrates how to create an expression that represents an arithmetic negation operation.

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

// This expression represents a negation operation.
Expression negateExpr = Expression.Negate(Expression.Constant(5));

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

// This code example produces the following output:
//
// -5

' Add the following directive to your file:
' Imports System.Linq.Expressions 

' This expression represents a negation operation.
Dim negateExpr As Expression = Expression.Negate(Expression.Constant(5))

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

' This code example produces the following output:
'
' -5

Комментарии

Свойству полученного результата UnaryExpression присваивается метод реализации. MethodThe Method property of the resulting UnaryExpression is set to the implementing method. Для Type свойства задается тип узла.The Type property is set to the type of the node. Если узел ликвидируется, IsLifted свойства и IsLiftedToNull являются обоими true.If the node is lifted, the IsLifted and IsLiftedToNull properties are both true. В противном случае они имеют значение false.Otherwise, they are false.

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

Следующие правила определяют метод реализации для операции.The following rules determine the implementing method for the operation:

  • Если expression. Тип — это определяемый пользователем тип, определяющий унарный минус-оператор MethodInfo , который представляет этот оператор в качестве метода реализации.If expression.Type is a user-defined type that defines the unary minus operator, the MethodInfo that represents that operator is the implementing method.

  • В противном expressionслучае значение, если. Type является числовым типом, метод реализации — null.Otherwise, if expression.Type is a numeric type, the implementing method is null.

Тип узла и сравнение с нулификацией и без негоNode Type and Lifted versus Non-Lifted

Если метод реализации не nullимеет:If the implementing method is not null:

  • Если expression. Тип может быть назначен типу аргумента реализующего метода, узел не ликвидируется.If expression.Type is assignable to the argument type of the implementing method, the node is not lifted. Тип узла является типом возвращаемого значения метода реализации.The type of the node is the return type of the implementing method.

  • Если выполняются следующие два условия, узел ликвидируется, и тип узла является типом, допускающим значение null, который соответствует типу возвращаемого значения метода реализации:If the following two conditions are satisfied, the node is lifted and the type of the node is the nullable type that corresponds to the return type of the implementing method:

    • expression. Тип является типом значения, допускающим значение null, и соответствующий тип значения, не допускающий значения NULL, равен типу аргумента реализующего метода.expression.Type is a nullable value type and the corresponding non-nullable value type is equal to the argument type of the implementing method.

    • Возвращаемый тип метода реализации является типом значения, не допускающим значения NULL.The return type of the implementing method is a non-nullable value type.

Если метод реализации имеет значение null, тип узла —. expression Тип.If the implementing method is null, the type of the node is expression.Type. Если expression. Тип не допускает значения NULL, узел не ликвидируется.If expression.Type is non-nullable, the node is not lifted. В противном случае узел ликвидируется.Otherwise, the node is lifted.

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