Expression.Multiply Methode
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Hiermee maakt u een BinaryExpression bewerking voor rekenkundige vermenigvuldiging die geen controle van overloop heeft.
Overloads
| Name | Description |
|---|---|
| Multiply(Expression, Expression, MethodInfo) |
Hiermee maakt u een BinaryExpression bewerking voor rekenkundige vermenigvuldiging die geen controle van overloop heeft. |
| Multiply(Expression, Expression) |
Hiermee maakt u een BinaryExpression bewerking voor rekenkundige vermenigvuldiging die geen controle van overloop heeft. |
Multiply(Expression, Expression, MethodInfo)
Hiermee maakt u een BinaryExpression bewerking voor rekenkundige vermenigvuldiging die geen controle van overloop heeft.
public:
static System::Linq::Expressions::BinaryExpression ^ Multiply(System::Linq::Expressions::Expression ^ left, System::Linq::Expressions::Expression ^ right, System::Reflection::MethodInfo ^ method);
public static System.Linq.Expressions.BinaryExpression Multiply(System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right, System.Reflection.MethodInfo method);
static member Multiply : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression * System.Reflection.MethodInfo -> System.Linq.Expressions.BinaryExpression
Public Shared Function Multiply (left As Expression, right As Expression, method As MethodInfo) As BinaryExpression
Parameters
- left
- Expression
Een Expression om de Left eigenschap in te stellen die gelijk is aan.
- right
- Expression
Een Expression om de Right eigenschap in te stellen die gelijk is aan.
- method
- MethodInfo
A MethodInfo om de Method eigenschap in te stellen die gelijk is aan.
Retouren
Een BinaryExpression met de NodeType eigenschap gelijk aan Multiply en de Left, Righten Method eigenschappen die zijn ingesteld op de opgegeven waarden.
Uitzonderingen
left of right is null.
method is niet null en de methode die deze vertegenwoordigt, retourneert void, is niet static (Shared in Visual Basic) of neemt niet precies twee argumenten.
method is null en de vermenigvuldigingsoperator is niet gedefinieerd voor left. Typ en right. Type.
Opmerkingen
De resulterende BinaryExpression eigenschap is Method ingesteld op de implementatiemethode. De Type eigenschap is ingesteld op het type knooppunt. Als het knooppunt wordt opgeheven, zijn de IsLifted en IsLiftedToNull eigenschappen beide true. Anders zijn ze false. De eigenschap Conversion is null.
De volgende informatie beschrijft de implementatiemethode, het knooppunttype en of een knooppunt wordt opgeheven.
Implementatiemethode
De volgende regels bepalen de implementatiemethode voor de bewerking:
Als
methodniet isnullen deze een niet-ongeldigestatic(Sharedin Visual Basic) vertegenwoordigt, is dit de implementatiemethode voor het knooppunt.Als de eigenschap van een van
leftbeide ofrighteen door de Type gebruiker gedefinieerd type vertegenwoordigt dat de vermenigvuldigingsoperator overbelast, is de methode die MethodInfo de implementatiemethode vertegenwoordigt.Anders, als
left.Type enright.Type numerieke typen zijn, is de implementatiemethodenull.
Type knooppunt en opgeheven versus niet-opgeheven
Als de implementatiemethode niet null is:
Als
left.Type enright.Type kunnen worden toegewezen aan de bijbehorende argumenttypen van de implementatiemethode, dan wordt het knooppunt niet opgeheven. Het type van het knooppunt is het retourtype van de implementatiemethode.Als aan de volgende twee voorwaarden wordt voldaan, wordt het knooppunt opgeheven en is het type van het knooppunt het type null dat overeenkomt met het retourtype van de implementatiemethode:
left.Type enright.Type zijn beide waardetypen waarvan er ten minste één nullable is, en de bijbehorende niet-nullable typen zijn gelijk aan de overeenkomstige argumenttypen van de implementatiemethode.Het retourtype van de implementatiemethode is een niet-null-waardetype.
Als de implementatiemethode het volgende is null:
Als zowel
left.Type alsright.Type niet-nulbaar zijn, wordt het knooppunt niet opgeheven. Het type van het knooppunt is het resultaattype van de vooraf gedefinieerde vermenigvuldigingsoperator.Als zowel
left.Type alsright.Type beide null-waarden kunnen hebben, wordt het knooppunt verheven. Het type van het knooppunt is het null-type dat overeenkomt met het resultaattype van de vooraf gedefinieerde vermenigvuldigingsoperator.
Van toepassing op
Multiply(Expression, Expression)
Hiermee maakt u een BinaryExpression bewerking voor rekenkundige vermenigvuldiging die geen controle van overloop heeft.
public:
static System::Linq::Expressions::BinaryExpression ^ Multiply(System::Linq::Expressions::Expression ^ left, System::Linq::Expressions::Expression ^ right);
public static System.Linq.Expressions.BinaryExpression Multiply(System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right);
static member Multiply : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression -> System.Linq.Expressions.BinaryExpression
Public Shared Function Multiply (left As Expression, right As Expression) As BinaryExpression
Parameters
- left
- Expression
Een Expression om de Left eigenschap in te stellen die gelijk is aan.
- right
- Expression
Een Expression om de Right eigenschap in te stellen die gelijk is aan.
Retouren
Een BinaryExpression met de NodeType eigenschap gelijk aan Multiply en de Left eigenschappen die Right zijn ingesteld op de opgegeven waarden.
Uitzonderingen
left of right is null.
De vermenigvuldigingsoperator is niet gedefinieerd voor left. Typ en right. Type.
Voorbeelden
In het volgende codevoorbeeld ziet u hoe u een expressie maakt waarmee twee waarden worden vermenigvuldigd.
// Add the following directive to your file:
// using System.Linq.Expressions;
// This expression multiplies its two arguments.
// Both arguments must be of the same type.
Expression multiplyExpr = Expression.Multiply(
Expression.Constant(10),
Expression.Constant(4)
);
// Print out the expression.
Console.WriteLine(multiplyExpr.ToString());
// The following statement first creates an expression tree,
// then compiles it, and then executes it.
Console.WriteLine(
Expression.Lambda<Func<int>>(multiplyExpr).Compile()());
// This code example produces the following output:
//
// (10*4)
// 40
' Add the following directive to your file:
' Imports System.Linq.Expressions
' This expression multiplies its two arguments.
' Both arguments must be of the same type.
Dim multiplyExpr As Expression = Expression.Multiply(
Expression.Constant(10),
Expression.Constant(4)
)
' Print the expression.
Console.WriteLine(multiplyExpr.ToString())
' The following statement first creates an expression tree,
' then compiles it, and then executes it.
Console.WriteLine(
Expression.Lambda(Of Func(Of Integer))(multiplyExpr).Compile()())
' This code example produces the following output:
'
' (10*4)
' 40
Opmerkingen
De resulterende BinaryExpression eigenschap is Method ingesteld op de implementatiemethode. De Type eigenschap is ingesteld op het type knooppunt. Als het knooppunt wordt opgeheven, zijn de IsLifted en IsLiftedToNull eigenschappen beide true. Anders zijn ze false. De eigenschap Conversion is null.
De volgende informatie beschrijft de implementatiemethode, het knooppunttype en of een knooppunt wordt opgeheven.
Implementatiemethode
De volgende regels bepalen de geselecteerde implementatiemethode voor de bewerking:
Als de Type eigenschap van een van
leftbeide ofrighteen door de gebruiker gedefinieerd type vertegenwoordigt dat de vermenigvuldigingsoperator overbelast, is de methode die MethodInfo de implementatiemethode vertegenwoordigt.Anders, als
left.Type enright.Type numerieke typen zijn, is de implementatiemethodenull.
Type knooppunt en opgeheven versus niet-opgeheven
Als de implementatiemethode niet null is:
Als
left.Type enright.Type kunnen worden toegewezen aan de bijbehorende argumenttypen van de implementatiemethode, dan wordt het knooppunt niet opgeheven. Het type van het knooppunt is het retourtype van de implementatiemethode.Als aan de volgende twee voorwaarden wordt voldaan, wordt het knooppunt opgeheven en is het type van het knooppunt het type null dat overeenkomt met het retourtype van de implementatiemethode:
left.Type enright.Type zijn beide waardetypen waarvan er ten minste één nullable is, en de bijbehorende niet-nullable typen zijn gelijk aan de overeenkomstige argumenttypen van de implementatiemethode.Het retourtype van de implementatiemethode is een niet-null-waardetype.
Als de implementatiemethode het volgende is null:
Als zowel
left.Type alsright.Type niet-nulbaar zijn, wordt het knooppunt niet opgeheven. Het type van het knooppunt is het resultaattype van de vooraf gedefinieerde vermenigvuldigingsoperator.Als zowel
left.Type alsright.Type beide null-waarden kunnen hebben, wordt het knooppunt verheven. Het type van het knooppunt is het null-type dat overeenkomt met het resultaattype van de vooraf gedefinieerde vermenigvuldigingsoperator.