Expression.Divide Expression.Divide Expression.Divide Expression.Divide Method

定義

算術除算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic division operation.

オーバーロード

Divide(Expression, Expression) Divide(Expression, Expression) Divide(Expression, Expression) Divide(Expression, Expression)

算術除算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic division operation.

Divide(Expression, Expression, MethodInfo) Divide(Expression, Expression, MethodInfo) Divide(Expression, Expression, MethodInfo) Divide(Expression, Expression, MethodInfo)

算術除算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic division operation. 実装メソッドを指定できます。The implementing method can be specified.

Divide(Expression, Expression) Divide(Expression, Expression) Divide(Expression, Expression) Divide(Expression, Expression)

算術除算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic division operation.

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

パラメーター

left
Expression Expression Expression Expression

Expression プロパティを設定する LeftAn Expression to set the Left property to.

right
Expression Expression Expression Expression

Expression プロパティを設定する RightAn Expression to set the Right property to.

戻り値

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

例外

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

除算演算子は、left.Type および right.Type に対して定義されていません。The division operator is not defined for left.Type and right.Type.

次のコード例では、その 2 つ目の引数で最初の引数を分割する式を作成する方法を示します。The following code example shows how to create an expression that divides its first argument by its second argument.

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

// This expression divides its first argument by its second argument.
// Both arguments must be of the same type.
Expression divideExpr = Expression.Divide(
    Expression.Constant(10.0),
    Expression.Constant(4.0)
);

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

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

// This code example produces the following output:
//
// (10/4)
// 2.5
' Add the following directive to your file:
' Imports System.Linq.Expressions   

' This expression divides its first argument by its second argument.
' Both arguments must be of the same type.
Dim divideExpr As Expression = Expression.Divide(
    Expression.Constant(10.0),
    Expression.Constant(4.0)
)

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

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

' This code example produces the following output:
'
' (10/4)
' 2.5

注釈

その結果、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:

  • 場合、Typeいずれかのプロパティleftまたはright、除算演算子をオーバー ロードするユーザー定義型を表す、MethodInfoメソッドがメソッドの実装を表します。If the Type property of either left or right represents a user-defined type that overloads the division 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 division 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 division operator.

Divide(Expression, Expression, MethodInfo) Divide(Expression, Expression, MethodInfo) Divide(Expression, Expression, MethodInfo) Divide(Expression, Expression, MethodInfo)

算術除算演算を表す BinaryExpression を作成します。Creates a BinaryExpression that represents an arithmetic division operation. 実装メソッドを指定できます。The implementing method can be specified.

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

パラメーター

left
Expression Expression Expression Expression

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

right
Expression Expression Expression Expression

Expression プロパティを等しく設定する RightAn 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 プロパティと、指定した値に設定された DivideLeft、および Right の各プロパティを含む MethodA BinaryExpression that has the NodeType property equal to Divide 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 division 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 division 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 division 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 division operator.

適用対象