Expression.Subtract 메서드

정의

오버플로를 검사하지 않는 산술 빼기 연산을 나타내는 BinaryExpression을 만듭니다.

오버로드

Subtract(Expression, Expression)

오버플로를 검사하지 않는 산술 빼기 연산을 나타내는 BinaryExpression을 만듭니다.

Subtract(Expression, Expression, MethodInfo)

오버플로를 검사하지 않는 산술 빼기 연산을 나타내는 BinaryExpression을 만듭니다.

Subtract(Expression, Expression)

Source:
BinaryExpression.cs
Source:
BinaryExpression.cs
Source:
BinaryExpression.cs

오버플로를 검사하지 않는 산술 빼기 연산을 나타내는 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이고 SubtractLeft 속성이 지정된 값으로 설정된 Right입니다.

예외

left 또는 rightnull인 경우

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

설명

결과에 BinaryExpressionMethod 구현 메서드로 설정된 속성이 있습니다. 속성은 Type 노드의 형식으로 설정됩니다. 노드가 해제되면 IsLiftedIsLiftedToNull 속성은 모두 true입니다. 그렇지 않으면 입니다 false. Conversion 속성은 null입니다.

다음 정보는 구현 메서드, 노드 유형 및 노드 해제 여부를 설명합니다.

구현 방법

다음 규칙은 작업에 대해 선택한 구현 메서드를 결정합니다.

  • 또는 leftright 의 속성이 Type 빼기 연산 MethodInfo 자를 오버로드하는 사용자 정의 형식을 나타내는 경우 해당 메서드를 나타내는 는 구현 메서드입니다.

  • 그렇지 않으면 이고, 그렇지 않으면 입니다 left. 및 를 입력합니다 right. 형식은 숫자 형식이고 구현 메서드는 입니다 null.

노드 유형 및 해제됨 및 해제되지 않은 노드

구현 메서드가 이 아닌 null경우:

  • 이면 left입니다. 및 를 입력합니다 right. 형식은 구현 메서드의 해당 인수 형식에 할당할 수 있으며 노드는 해제되지 않습니다. 노드의 형식은 구현 메서드의 반환 형식입니다.

  • 다음 두 조건이 충족되면 노드가 해제되고 노드의 형식은 구현 메서드의 반환 형식에 해당하는 null 허용 형식입니다.

    • left. 및 를 입력합니다 right. 형식은 둘 다 하나 이상의 null 허용 값 형식이며 해당 nullable이 아닌 형식은 구현 메서드의 해당 인수 형식과 같습니다.

    • 구현 메서드의 반환 형식은 nullable이 아닌 값 형식입니다.

구현 메서드가 인 경우:null

  • 이면 left입니다. 및 를 입력합니다 right. 형식은 모두 null 허용이 아니고 노드가 해제되지 않습니다. 노드의 형식은 미리 정의된 빼기 연산자의 결과 형식입니다.

  • 이면 left입니다. 및 를 입력합니다 right. 형식은 모두 null 허용이며 노드가 해제됩니다. 노드의 형식은 미리 정의된 빼기 연산자의 결과 형식에 해당하는 nullable 형식입니다.

적용 대상

Subtract(Expression, Expression, MethodInfo)

Source:
BinaryExpression.cs
Source:
BinaryExpression.cs
Source:
BinaryExpression.cs

오버플로를 검사하지 않는 산술 빼기 연산을 나타내는 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, LeftRight 속성이 지정된 값으로 설정된 Method입니다.

예외

left 또는 rightnull인 경우

methodnull이 아니고 이것이 나타내는 메서드가 void를 반환하거나, static(Visual Basic의 Shared)이 아니거나, 정확히 두 개의 인수를 사용하지 않는 경우

methodnull이고 빼기 연산자가 left.Type 및 right.Type에 대해 정의되지 않은 경우

설명

결과에 BinaryExpressionMethod 구현 메서드로 설정된 속성이 있습니다. 속성은 Type 노드의 형식으로 설정됩니다. 노드가 해제되면 IsLiftedIsLiftedToNull 속성은 모두 true입니다. 그렇지 않으면 입니다 false. Conversion 속성은 null입니다.

다음 정보는 구현 메서드, 노드 유형 및 노드 해제 여부를 설명합니다.

구현 방법

다음 규칙은 작업에 대한 구현 메서드를 결정합니다.

  • 가 이 아니고 두 개의 인수를 사용하는 void static 가 아닌 null (Shared Visual Basic의 경우) 메서드를 나타내는 경우 method 노드에 대한 구현 메서드입니다.

  • 그렇지 않으면 또는 rightleft 속성이 Type 빼기 연산 MethodInfo 자를 오버로드하는 사용자 정의 형식을 나타내는 경우 해당 메서드를 나타내는 는 구현 메서드입니다.

  • 그렇지 않으면 이고, 그렇지 않으면 입니다 left. 및 를 입력합니다 right. 형식은 숫자 형식이고 구현 메서드는 입니다 null.

노드 유형 및 해제됨 및 해제되지 않은 노드

구현 메서드가 이 아닌 null경우:

  • 이면 left입니다. 및 를 입력합니다 right. 형식은 구현 메서드의 해당 인수 형식에 할당할 수 있으며 노드는 해제되지 않습니다. 노드의 형식은 구현 메서드의 반환 형식입니다.

  • 다음 두 조건이 충족되면 노드가 해제되고 노드의 형식은 구현 메서드의 반환 형식에 해당하는 null 허용 형식입니다.

    • left. 및 를 입력합니다 right. 형식은 둘 다 하나 이상의 null 허용 값 형식이며 해당 nullable이 아닌 형식은 구현 메서드의 해당 인수 형식과 같습니다.

    • 구현 메서드의 반환 형식은 nullable이 아닌 값 형식입니다.

구현 메서드가 인 경우:null

  • 이면 left입니다. 및 를 입력합니다 right. 형식은 모두 null 허용이 아니고 노드가 해제되지 않습니다. 노드의 형식은 미리 정의된 빼기 연산자의 결과 형식입니다.

  • 이면 left입니다. 및 를 입력합니다 right. 형식은 모두 null 허용이며 노드가 해제됩니다. 노드의 형식은 미리 정의된 빼기 연산자의 결과 형식에 해당하는 nullable 형식입니다.

적용 대상