Expression.OrElse Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Crée un BinaryExpression qui représente une opération OR
conditionnelle évaluant la deuxième opérande uniquement si le premier opérateur a la valeur false
.
Surcharges
OrElse(Expression, Expression) |
Crée un BinaryExpression qui représente une opération |
OrElse(Expression, Expression, MethodInfo) |
Crée un BinaryExpression qui représente une opération |
OrElse(Expression, Expression)
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
Crée un BinaryExpression qui représente une opération OR
conditionnelle évaluant la deuxième opérande uniquement si la première opérande a la valeur false
.
public:
static System::Linq::Expressions::BinaryExpression ^ OrElse(System::Linq::Expressions::Expression ^ left, System::Linq::Expressions::Expression ^ right);
public static System.Linq.Expressions.BinaryExpression OrElse (System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right);
static member OrElse : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression -> System.Linq.Expressions.BinaryExpression
Public Shared Function OrElse (left As Expression, right As Expression) As BinaryExpression
Paramètres
- left
- Expression
Expression auquel la propriété Left doit être égale.
- right
- Expression
Expression auquel la propriété Right doit être égale.
Retours
BinaryExpression dont la propriété NodeType est égale à OrElse et dont les propriétés Left et Right ont les valeurs spécifiées.
Exceptions
left
ou right
est null
.
L'opérateur de bits OR
n'est pas défini pour left
.Type et right
.Type.
- ou -
left
.Type et right
.Type ne sont pas du même type booléen.
Exemples
L’exemple de code suivant montre comment créer une expression qui représente une opération logique OR
qui évalue le deuxième opérande uniquement si le premier opérande prend false
la valeur .
// Add the following directive to your file:
// using System.Linq.Expressions;
// This expression perfroms a logical OR operation
// on its two arguments, but if the first argument is true,
// then the second arument is not evaluated.
// Both arguments must be of the boolean type.
Expression orElseExpr = Expression.OrElse(
Expression.Constant(false),
Expression.Constant(true)
);
// Print out the expression.
Console.WriteLine(orElseExpr.ToString());
// The following statement first creates an expression tree,
// then compiles it, and then executes it.
Console.WriteLine(Expression.Lambda<Func<bool>>(orElseExpr).Compile().Invoke());
// This code example produces the following output:
//
// (False OrElse True)
// True
' Add the following directive to your file:
' Imports System.Linq.Expressions
' This expression perfroms a logical OR operation
' on its two arguments, but if the first argument is true,
' the second arument is not evaluated.
' Both arguments must be of the Boolean type.
Dim orElseExpr As Expression = Expression.OrElse(
Expression.Constant(False),
Expression.Constant(True)
)
' Print the expression.
Console.WriteLine(orElseExpr.ToString())
' The following statement first creates an expression tree,
' then compiles it, and then executes it.
Console.WriteLine(Expression.Lambda(Of Func(Of Boolean))(orElseExpr).Compile()())
' This code example produces the following output:
'
' (False OrElse True)
' True
Remarques
La propriété résultante BinaryExpression est Method définie sur la méthode d’implémentation. La Type propriété est définie sur le type du nœud. Si le nœud est levé, les propriétés et IsLiftedToNull sont à la IsLifted fois true
. Sinon, il s’agit de false
. La propriété Conversion a la valeur null
.
Les informations suivantes décrivent la méthode d’implémentation, le type de nœud et si un nœud est levé.
Implémentation de la méthode
Les règles suivantes déterminent la méthode d’implémentation de l’opération :
Si la Type propriété de
left
ouright
représente un type défini par l’utilisateur qui surcharge l’opérateur au niveauOR
du bit, le MethodInfo qui représente cette méthode est la méthode d’implémentation.Notes
L’opérateur conditionnel
OR
ne peut pas être surchargé en C# ou Visual Basic. Toutefois, l’opérateur conditionnelOR
est évalué à l’aide de l’opérateur au niveauOR
du bit. Ainsi, une surcharge définie par l’utilisateur de l’opérateur au niveauOR
du bit peut être la méthode d’implémentation pour ce type de nœud.Sinon, si
left
. Tapez etright
. Les types sont booléens, la méthode d’implémentation estnull
.
Type de nœud et lifté par rapport à non lifté
Si la méthode d’implémentation n’est pas null
:
Si
left
. Tapez etright
. Les types sont assignables aux types d’arguments correspondants de la méthode d’implémentation. Le nœud n’est pas levé. Le type du nœud est le type de retour de la méthode d’implémentation.Si les deux conditions suivantes sont remplies, le nœud est levé et le type du nœud est le type nullable qui correspond au type de retour de la méthode d’implémentation :
left
. Tapez etright
. Le type est deux types de valeurs dont au moins un est nullable et les types non nullables correspondants sont égaux aux types d’arguments correspondants de la méthode d’implémentation.Le type de retour de la méthode d’implémentation est un type valeur non nullable.
Si la méthode d’implémentation est null
:
left
. Tapez etright
. Le type est le même type booléen.Si
left
. Tapez etright
. Les types ne sont pas nullables, le nœud n’est pas levé. Le type du nœud est le type de résultat de l’opérateur conditionnelOR
prédéfini.Si
left
. Tapez etright
. Les types sont nullables, le nœud est levé. Le type du nœud est le type nullable qui correspond au type de résultat de l’opérateur conditionnelOR
prédéfini.
S’applique à
OrElse(Expression, Expression, MethodInfo)
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
Crée un BinaryExpression qui représente une opération OR
conditionnelle évaluant la deuxième opérande uniquement si la première opérande a la valeur false
.
public:
static System::Linq::Expressions::BinaryExpression ^ OrElse(System::Linq::Expressions::Expression ^ left, System::Linq::Expressions::Expression ^ right, System::Reflection::MethodInfo ^ method);
public static System.Linq.Expressions.BinaryExpression OrElse (System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right, System.Reflection.MethodInfo method);
public static System.Linq.Expressions.BinaryExpression OrElse (System.Linq.Expressions.Expression left, System.Linq.Expressions.Expression right, System.Reflection.MethodInfo? method);
static member OrElse : System.Linq.Expressions.Expression * System.Linq.Expressions.Expression * System.Reflection.MethodInfo -> System.Linq.Expressions.BinaryExpression
Public Shared Function OrElse (left As Expression, right As Expression, method As MethodInfo) As BinaryExpression
Paramètres
- left
- Expression
Expression auquel la propriété Left doit être égale.
- right
- Expression
Expression auquel la propriété Right doit être égale.
- method
- MethodInfo
MethodInfo auquel la propriété Method doit être égale.
Retours
BinaryExpression dont la propriété NodeType est égale à OrElse et dont les propriétés Left, Right et Method ont les valeurs spécifiées.
Exceptions
left
ou right
est null
.
method
n’est pas null
et la méthode représentée retourne void
, pas static
(Shared
dans Visual Basic) ou ne prend pas exactement deux arguments.
method
est null
et l’opérateur OR
au niveau du bit n’est pas défini pour les types left
.et right
.
- ou -
method
est null
et left
.Type et right
.Type ne sont pas du même type booléen.
Remarques
La propriété résultante BinaryExpression est Method définie sur la méthode d’implémentation. La Type propriété est définie sur le type du nœud. Si le nœud est levé, les propriétés et IsLiftedToNull sont à la IsLifted fois true
. Sinon, il s’agit de false
. La propriété Conversion a la valeur null
.
Les informations suivantes décrivent la méthode d’implémentation, le type de nœud et si un nœud est levé.
Implémentation de la méthode
Les règles suivantes déterminent la méthode d’implémentation de l’opération :
Si
method
n’est pasnull
et qu’il représente une méthode non void (static
Shared
en Visual Basic) qui prend deux arguments, il s’agit de la méthode d’implémentation pour le nœud.Sinon, si la Type propriété de
left
ouright
représente un type défini par l’utilisateur qui surcharge l’opérateur au niveauOR
du bit, le MethodInfo qui représente cette méthode est la méthode d’implémentation.Notes
L’opérateur conditionnel
OR
ne peut pas être surchargé en C# ou Visual Basic. Toutefois, l’opérateur conditionnelOR
est évalué à l’aide de l’opérateur au niveauOR
du bit. Ainsi, une surcharge définie par l’utilisateur de l’opérateur au niveauOR
du bit peut être la méthode d’implémentation pour ce type de nœud.Sinon, si
left
. Tapez etright
. Les types sont booléens, la méthode d’implémentation estnull
.
Type de nœud et lifté par rapport à non lifté
Si la méthode d’implémentation n’est pas null
:
Si
left
. Tapez etright
. Les types sont assignables aux types d’arguments correspondants de la méthode d’implémentation. Le nœud n’est pas levé. Le type du nœud est le type de retour de la méthode d’implémentation.Si les deux conditions suivantes sont remplies, le nœud est levé et le type du nœud est le type nullable qui correspond au type de retour de la méthode d’implémentation :
left
. Tapez etright
. Le type est deux types de valeurs dont au moins un est nullable et les types non nullables correspondants sont égaux aux types d’arguments correspondants de la méthode d’implémentation.Le type de retour de la méthode d’implémentation est un type valeur non nullable.
Si la méthode d’implémentation est null
:
left
. Tapez etright
. Le type est le même type booléen.Si
left
. Tapez etright
. Les types ne sont pas nullables, le nœud n’est pas levé. Le type du nœud est le type de résultat de l’opérateur conditionnelOR
prédéfini.Si
left
. Tapez etright
. Les types sont nullables, le nœud est levé. Le type du nœud est le type nullable qui correspond au type de résultat de l’opérateur conditionnelOR
prédéfini.