Expression.AddChecked Метод

Определение

Создает BinaryExpression , представляющий операцию арифметического сложения, содержащую проверку переполнения.Creates a BinaryExpression that represents an arithmetic addition operation that has overflow checking.

Перегрузки

AddChecked(Expression, Expression)

Создает BinaryExpression, представляющий операцию арифметического сложения, содержащую проверку переполнения.Creates a BinaryExpression that represents an arithmetic addition operation that has overflow checking.

AddChecked(Expression, Expression, MethodInfo)

Создает BinaryExpression, представляющий операцию арифметического сложения, содержащую проверку переполнения.Creates a BinaryExpression that represents an arithmetic addition operation that has overflow checking. Может быть указан метод реализации.The implementing method can be specified.

AddChecked(Expression, Expression)

Создает BinaryExpression, представляющий операцию арифметического сложения, содержащую проверку переполнения.Creates a BinaryExpression that represents an arithmetic addition operation that has overflow checking.

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

Параметры

left
Expression

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

right
Expression

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

Возвраты

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

Исключения

Значение параметра left или rightnull.left or right is null.

Оператор сложения не определен для типов left.Type и right.Type.The addition operator is not defined for left.Type and right.Type.

Комментарии

В результирующем BinaryExpression Method окне свойство устанавливается в метод реализации.The resulting BinaryExpression has the Method property 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. В противном случае —. falseOtherwise, they are false. Значение свойства Conversionnull.The Conversion property is null.

Ниже приведена информация о методе реализации, типе узла и том, ликвидируется ли узел.The following information describes the implementing method, the node type, and whether a node is lifted.

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

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

  • left Если свойство либо представляет собой определяемый пользователем тип, который перегружает оператор сложения, то объект MethodInfo , представляющий метод, является реализующим методом. right TypeIf the Type property of either left or right represents a user-defined type that overloads the addition operator, the MethodInfo that represents that method is the implementing method.

  • В противном leftслучае значение, если. Введите и right. Type являются числовыми типами, метод реализации — null.Otherwise, if left.Type and right.Type are numeric types, the implementing method is null.

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

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

  • Если left. Введите и right. Тип могут быть назначены соответствующим типам аргументов реализующего метода, узел не ликвидируется.If left.Type and right.Type are assignable to the corresponding argument types 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:

    • left. Введите и right. Type — это типы значений, в которых по крайней мере один допускает значение null, а соответствующие типы, не допускающие значения NULL, равны соответствующим типам аргументов реализующего метода.left.Type and right.Type are both value types of which at least one is nullable and the corresponding non-nullable types are equal to the corresponding argument types of the implementing method.

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

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

  • Если left. Введите и right. Тип не допускает значения NULL, узел не ликвидируется.If left.Type and right.Type are both non-nullable, the node is not lifted. Тип узла является типом результата предопределенного оператора сложения.The type of the node is the result type of the predefined addition operator.

  • Если left. Введите и right. Type допускают значение null, узел ликвидируется.If left.Type and right.Type are both nullable, the node is lifted. Тип узла является типом, допускающим значение null, который соответствует типу результата предопределенного оператора сложения.The type of the node is the nullable type that corresponds to the result type of the predefined addition operator.

AddChecked(Expression, Expression, MethodInfo)

Создает BinaryExpression, представляющий операцию арифметического сложения, содержащую проверку переполнения.Creates a BinaryExpression that represents an arithmetic addition operation that has overflow checking. Может быть указан метод реализации.The implementing method can be specified.

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

Параметры

left
Expression

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

right
Expression

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

method
MethodInfo

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

Возвраты

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

Исключения

Значение параметра left или rightnull.left or right 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 two arguments.

method имеет значение null , и оператор сложения не определен для left.Type и right.Type.method is null and the addition operator is not defined for left.Type and right.Type.

Комментарии

В результирующем BinaryExpression Method окне свойство устанавливается в метод реализации.The resulting BinaryExpression has the Method property 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. В противном случае —. falseOtherwise, they are false. Значение свойства Conversionnull.The Conversion property is null.

Ниже приведена информация о методе реализации, типе узла и том, ликвидируется ли узел.The following information describes the implementing method, the node type, and whether a node is lifted.

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

Метод реализации для операции выбирается на основе следующих правил.The implementing method for the operation is chosen based on the following rules:

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

  • В противном случае Type , если свойство left right либо представляет собой определяемый пользователем тип, который перегружает оператор сложения, объект MethodInfo , представляющий метод, является реализующим методом.Otherwise, if the Type property of either left or right represents a user-defined type that overloads the addition operator, the MethodInfo that represents that method is the implementing method.

  • В противном leftслучае значение, если. Введите и right. Type являются числовыми типами, метод реализации — null.Otherwise, if left.Type and right.Type are numeric types, the implementing method is null.

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

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

  • Если left. Введите и right. Тип могут быть назначены соответствующим типам аргументов реализующего метода, узел не ликвидируется.If left.Type and right.Type are assignable to the corresponding argument types 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:

    • left. Введите и right. Type — это типы значений, в которых по крайней мере один допускает значение null, а соответствующие типы, не допускающие значения NULL, равны соответствующим типам аргументов реализующего метода.left.Type and right.Type are both value types of which at least one is nullable and the corresponding non-nullable types are equal to the corresponding argument types of the implementing method.

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

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

  • Если left. Введите и right. Тип не допускает значения NULL, узел не ликвидируется.If left.Type and right.Type are both non-nullable, the node is not lifted. Тип узла является типом результата предопределенного оператора сложения.The type of the node is the result type of the predefined addition operator.

  • Если left. Введите и right. Type допускают значение null, узел ликвидируется.If left.Type and right.Type are both nullable, the node is lifted. Тип узла является типом, допускающим значение null, который соответствует типу результата предопределенного оператора сложения.The type of the node is the nullable type that corresponds to the result type of the predefined addition operator.

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