Udostępnij za pośrednictwem


Expression.Divide Metoda

Definicja

Tworzy obiekt BinaryExpression reprezentujący operację dzielenia arytmetycznego.

Przeciążenia

Nazwa Opis
Divide(Expression, Expression)

Tworzy obiekt BinaryExpression reprezentujący operację dzielenia arytmetycznego.

Divide(Expression, Expression, MethodInfo)

Tworzy obiekt BinaryExpression reprezentujący operację dzielenia arytmetycznego. Można określić metodę implementowania.

Divide(Expression, Expression)

Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs

Tworzy obiekt BinaryExpression reprezentujący operację dzielenia arytmetycznego.

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

Parametry

left
Expression

Element Expression , aby ustawić Left właściwość na .

right
Expression

Element Expression , aby ustawić Right właściwość na .

Zwraca

WłaściwośćBinaryExpression, która ma właściwość równą DivideNodeType i Left właściwości i Right ustawioną na określone wartości.

Wyjątki

left lub right ma wartość null.

Operator dzielenia nie jest zdefiniowany dla elementu left. Wpisz i right. Typu.

Przykłady

W poniższym przykładzie kodu pokazano, jak utworzyć wyrażenie, które dzieli swój pierwszy argument przez drugi 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

Uwagi

BinaryExpression Wynik ma właściwość ustawioną Method na metodę implementowania. Właściwość Type jest ustawiona na typ węzła. Jeśli węzeł zostanie podniesiony, zarówno właściwość IsLifted, jak i właściwość IsLiftedToNulltrue. W przeciwnym razie są to false. Właściwość Conversion jest null.

Poniższe informacje opisują metodę implementowania, typ węzła i informację, czy węzeł jest zniesiony.

Implementowanie metody

Następujące reguły określają metodę implementowania dla operacji:

  • Type Jeśli właściwość lub leftright reprezentuje typ zdefiniowany przez użytkownika, który przeciąża operator dzielenia, oznacza to, MethodInfo że metoda jest metodą implementowania.

  • W przeciwnym razie, jeśli left.Type i right.Type są typami liczbowymi, metodą implementacji jest null.

Typ węzła i podniesiony a nieznoszony

Jeśli metoda implementacji nie jest null:

  • Jeśli typy left.Typ i right.Typ można przypisać do odpowiednich typów argumentów metody implementacyjnej, węzeł nie jest podnoszony. Typ węzła to zwracany typ metody implementowania.

  • Jeśli spełnione są następujące dwa warunki, węzeł zostanie zniesiony, a typ węzła jest typem dopuszczalnym wartości null odpowiadającym zwracanym typowi metody implementowania:

    • left.Typ i right.Typ to oba typy wartości, z których co najmniej jeden może przyjmować wartość null, a odpowiadające im typy nie-null są równe odpowiadającym typom argumentów metody implementującej.

    • Typ zwracany przez metodę implementacji jest niemającym wartości null typem wartościowym.

Jeśli metoda implementowania to null:

  • Jeśli zarówno left.Typ, jak i right.Typ są niemające wartości null, węzeł nie zostanie podniesiony. Typ węzła jest typem wyniku wstępnie zdefiniowanego operatora dzielenia.

  • Jeśli left. Typ i right. Typ oba mają wartość null, to węzeł jest podnoszony. Typ węzła to typ dopuszczający wartość null, który odpowiada typowi wyniku wstępnie zdefiniowanego operatora dzielenia.

Dotyczy

Divide(Expression, Expression, MethodInfo)

Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs
Źródło:
BinaryExpression.cs

Tworzy obiekt BinaryExpression reprezentujący operację dzielenia arytmetycznego. Można określić metodę implementowania.

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);
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

Parametry

left
Expression

Wartość , Expression aby ustawić właściwość równą Left .

right
Expression

Wartość , Expression aby ustawić właściwość równą Right .

method
MethodInfo

A MethodInfo , aby ustawić właściwość równą Method .

Zwraca

WłaściwośćBinaryExpression, która ma właściwość równą DivideNodeType , i LeftRight, i właściwości Method ustawione na określone wartości.

Wyjątki

left lub right ma wartość null.

method nie null jest i metoda, która reprezentuje, zwraca voidwartość , nie static jest (Shared w Visual Basic) lub nie bierze dokładnie dwóch argumentów.

method jest null i operator dzielenia nie jest zdefiniowany dla left. Wpisz i right. Typu.

Uwagi

BinaryExpression Wynik ma właściwość ustawioną Method na metodę implementowania. Właściwość Type jest ustawiona na typ węzła. Jeśli węzeł zostanie podniesiony, zarówno właściwość IsLifted, jak i właściwość IsLiftedToNulltrue. W przeciwnym razie są to false. Właściwość Conversion jest null.

Poniższe informacje opisują metodę implementowania, typ węzła i informację, czy węzeł jest zniesiony.

Implementowanie metody

Następujące reguły określają metodę implementowania dla operacji:

  • Jeśli method nie null jest i reprezentuje metodę niepustą ( staticShared w Visual Basic), która przyjmuje dwa argumenty, jest to metoda implementowania dla węzła.

  • W przeciwnym razie, jeśli Type właściwość left lub right reprezentuje typ zdefiniowany przez użytkownika, który przeciąża operator dzielenia, oznacza to, MethodInfo że metoda jest metodą implementowania.

  • W przeciwnym razie, jeśli left.Type i right.Type są typami liczbowymi, metodą implementacji jest null.

Typ węzła i podniesiony a nieznoszony

Jeśli metoda implementacji nie jest null:

  • Jeśli typy left.Typ i right.Typ można przypisać do odpowiednich typów argumentów metody implementacyjnej, węzeł nie jest podnoszony. Typ węzła to zwracany typ metody implementowania.

  • Jeśli spełnione są następujące dwa warunki, węzeł zostanie zniesiony, a typ węzła jest typem dopuszczalnym wartości null odpowiadającym zwracanym typowi metody implementowania:

    • left.Typ i right.Typ to oba typy wartości, z których co najmniej jeden może przyjmować wartość null, a odpowiadające im typy nie-null są równe odpowiadającym typom argumentów metody implementującej.

    • Typ zwracany przez metodę implementacji jest niemającym wartości null typem wartościowym.

Jeśli metoda implementowania to null:

  • Jeśli zarówno left.Typ, jak i right.Typ są niemające wartości null, węzeł nie zostanie podniesiony. Typ węzła jest typem wyniku wstępnie zdefiniowanego operatora dzielenia.

  • Jeśli left. Typ i right. Typ oba mają wartość null, to węzeł jest podnoszony. Typ węzła to typ dopuszczający wartość null, który odpowiada typowi wyniku wstępnie zdefiniowanego operatora dzielenia.

Dotyczy