Expression.Add Expression.Add Expression.Add Expression.Add Method

定義

オーバーフロー チェックを行わない算術加算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic addition operation that does not have overflow checking.

オーバーロード

Add(Expression, Expression) Add(Expression, Expression) Add(Expression, Expression) Add(Expression, Expression)

オーバーフロー チェックを行わない算術加算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic addition operation that does not have overflow checking.

Add(Expression, Expression, MethodInfo) Add(Expression, Expression, MethodInfo) Add(Expression, Expression, MethodInfo) Add(Expression, Expression, MethodInfo)

オーバーフロー チェックを行わない算術加算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic addition operation that does not have overflow checking. 実装メソッドを指定できます。The implementing method can be specified.

Add(Expression, Expression) Add(Expression, Expression) Add(Expression, Expression) Add(Expression, Expression)

オーバーフロー チェックを行わない算術加算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic addition operation that does not have overflow checking.

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

パラメーター

left
Expression Expression Expression Expression

Expression プロパティを等しく設定する LeftA Expression to set the Left property equal to.

right
Expression Expression Expression Expression

Expression プロパティを等しく設定する RightA Expression to set the Right property equal to.

戻り値

BinaryExpression と等しい NodeType プロパティと、指定した値に設定された Add プロパティおよび Left プロパティを含む RightA BinaryExpression that has the NodeType property equal to Add 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.

次のコード例では、2 つの整数を追加する式を作成する方法を示します。The following code example shows how to create an expression that adds two integers.

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

// This expression adds the values of its two arguments.
// Both arguments must be of the same type.
Expression sumExpr = Expression.Add(
    Expression.Constant(1),
    Expression.Constant(2)
);

// Print out the expression.
Console.WriteLine(sumExpr.ToString());

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

// This code example produces the following output:
//
// (1 + 2)
// 3
' Add the following directive to your file:
' Imports System.Linq.Expressions  

' This expression adds the values of its two arguments.
' Both arguments must be of the same type.
Dim sumExpr As Expression = Expression.Add(
    Expression.Constant(1),
    Expression.Constant(2)
    )

' Print the expression.
Console.WriteLine(sumExpr.ToString())

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

' This code example produces the following output:
'
' (1 + 2)
' 3

注釈

その結果、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. ノードがリフトされた場合、IsLiftedIsLiftedToNullプロパティが両方ともtrueします。If the node is lifted, the IsLifted and IsLiftedToNull properties are both true. それ以外の場合はfalseします。Otherwise, they are false. Conversion プロパティが null である。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 selected implementing method for the operation:

  • 場合、Typeいずれかのプロパティleftまたはright、加算演算子をオーバー ロードするユーザー定義型を表す、MethodInfoメソッドがメソッドの実装を表します。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します。型が数値型、メソッドの実装は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.

  • 次の 2 つの条件が満たされている場合は、ノードがリフトし、ノードの型は、実装メソッドの戻り値の型に対応する 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します。種類は、両方が値型を少なくとも 1 つが 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します。種類は、両方の 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.

Add(Expression, Expression, MethodInfo) Add(Expression, Expression, MethodInfo) Add(Expression, Expression, MethodInfo) Add(Expression, Expression, MethodInfo)

オーバーフロー チェックを行わない算術加算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic addition operation that does not have overflow checking. 実装メソッドを指定できます。The implementing method can be specified.

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

パラメーター

left
Expression Expression Expression Expression

Expression プロパティを等しく設定する LeftA Expression to set the Left property equal to.

right
Expression Expression Expression Expression

Expression プロパティを等しく設定する RightA Expression to set the Right property equal to.

method
MethodInfo MethodInfo MethodInfo MethodInfo

MethodInfo プロパティを等しく設定する MethodA MethodInfo to set the Method property equal to.

戻り値

BinaryExpression と等しい NodeType プロパティと、指定した値に設定された AddLeft、および Right の各プロパティを含む MethodA BinaryExpression that has the NodeType property equal to Add and the Left, Right and Method properties set to the specified values.

例外

left または rightnull です。left or right is null.

methodnull ではなく、それを表すメソッドは void を返し、static (Visual Basic では Shared) ではなく、またはちょうど 2 つの引数を受け取りません。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.

methodnull で、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. ノードがリフトされた場合、IsLiftedIsLiftedToNullプロパティが両方ともtrueします。If the node is lifted, the IsLifted and IsLiftedToNull properties are both true. それ以外の場合はfalseします。Otherwise, they are false. Conversion プロパティが null である。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:

  • 場合methodでないnullあり、void、以外を表しますstatic(Shared Visual Basic で) 2 つの引数を受け取るメソッドは、ノードのメソッドの実装。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します。型が数値型、メソッドの実装は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.

  • 次の 2 つの条件が満たされている場合は、ノードがリフトし、ノードの型は、実装メソッドの戻り値の型に対応する 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します。種類は、両方が値型を少なくとも 1 つが 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します。種類は、両方の 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.

適用対象