Expression.Subtract メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
オーバーフロー チェックを行わない算術減算演算を表す BinaryExpression を作成します。
オーバーロード
| Subtract(Expression, Expression) |
オーバーフロー チェックを行わない算術減算演算を表す BinaryExpression を作成します。 |
| Subtract(Expression, Expression, MethodInfo) |
オーバーフロー チェックを行わない算術減算演算を表す BinaryExpression を作成します。 |
Subtract(Expression, Expression)
オーバーフロー チェックを行わない算術減算演算を表す 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。
Conversion プロパティが null です。
次の情報では、実装メソッド、ノードの種類、およびノードがリフトされるかどうかについて説明します。
メソッドの実装
次の規則によって、操作の選択した実装方法が決まります。
または
rightのいずれかのleftプロパティがType、減算演算子をオーバーロードするユーザー定義型を表す場合、MethodInfoそのメソッドを表す は実装メソッドです。それ以外の場合
leftは 。と 入力しますright。型は数値型で、実装メソッドは ですnull。
ノードの種類とリフトされたノードと非リフト
実装メソッドが でない null場合:
の場合
left。と 入力しますright。型は実装メソッドの対応する引数型に割り当て可能であり、ノードはリフトされません。 ノードの型は、実装メソッドの戻り値の型です。次の 2 つの条件が満たされた場合、ノードはリフトされ、ノードの型は実装メソッドの戻り値の型に対応する null 許容型です。
left.と 入力しますright。型はどちらも、少なくとも 1 つが null 許容であり、対応する null 非許容型が実装メソッドの対応する引数型と等しい値型です。実装メソッドの戻り値の型は null 非許容値型です。
実装メソッドが の場合:null
の場合
left。と 入力しますright。型はどちらも null 非許容であり、ノードはリフトされません。 ノードの型は、定義済みの減算演算子の結果の種類です。の場合
left。と 入力しますright。型はどちらも null 許容であり、ノードはリフトされます。 ノードの型は、定義済みの減算演算子の結果の型に対応する null 許容型です。
適用対象
Subtract(Expression, Expression, MethodInfo)
オーバーフロー チェックを行わない算術減算演算を表す 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 (Visual Basic では Shared) ではなく、またはちょうど 2 つの引数を受け取りません。
method は null で、left.Type および right.Type には減算演算子が定義されていません。
注釈
結果 BinaryExpression の プロパティは、 Method 実装メソッドに設定されます。 プロパティは Type ノードの型に設定されます。 ノードがリフトされた場合、 IsLifted プロパティと IsLiftedToNull プロパティは両方とも trueになります。 それ以外の場合は です false。
Conversion プロパティが null です。
次の情報では、実装メソッド、ノードの種類、およびノードがリフトされるかどうかについて説明します。
メソッドの実装
次の規則は、操作の実装方法を決定します。
が でなく
null、static2 つの引数を受け取る非 void メソッド (SharedVisual Basic では) を表す場合methodは、ノードの実装メソッドです。それ以外の場合、 または
rightのいずれかのleftプロパティが減算演算子をオーバーロードするユーザー定義型を表す場合Type、MethodInfoそのメソッドを表す は実装メソッドです。それ以外の場合
leftは 。と 入力しますright。型は数値型で、実装メソッドは ですnull。
ノードの種類とリフトされたノードと非リフト
実装メソッドが でない null場合:
の場合
left。と 入力しますright。型は実装メソッドの対応する引数型に割り当て可能であり、ノードはリフトされません。 ノードの型は、実装メソッドの戻り値の型です。次の 2 つの条件が満たされた場合、ノードはリフトされ、ノードの型は実装メソッドの戻り値の型に対応する null 許容型です。
left.と 入力しますright。型はどちらも、少なくとも 1 つが null 許容であり、対応する null 非許容型が実装メソッドの対応する引数型と等しい値型です。実装メソッドの戻り値の型は null 非許容値型です。
実装メソッドが の場合:null
の場合
left。と 入力しますright。型はどちらも null 非許容であり、ノードはリフトされません。 ノードの型は、定義済みの減算演算子の結果の種類です。の場合
left。と 入力しますright。型はどちらも null 許容であり、ノードはリフトされます。 ノードの型は、定義済みの減算演算子の結果の型に対応する null 許容型です。