Expression.OrElse Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Cria um BinaryExpression que representa uma operação condicional OR que avalia o segundo operando somente se o primeiro operador for avaliado como false.
Sobrecargas
| Nome | Description |
|---|---|
| OrElse(Expression, Expression) |
Cria um BinaryExpression que representa uma operação condicional |
| OrElse(Expression, Expression, MethodInfo) |
Cria um BinaryExpression que representa uma operação condicional |
OrElse(Expression, Expression)
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
Cria um BinaryExpression que representa uma operação condicional OR que avalia o segundo operando somente se o primeiro operando for avaliado como 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
Parâmetros
- left
- Expression
Um Expression para definir a Left propriedade igual a.
- right
- Expression
Um Expression para definir a Right propriedade igual a.
Retornos
Um BinaryExpression que tem a NodeType propriedade igual a OrElse e as Left propriedades e Right definidas para os valores especificados.
Exceções
left ou right é null.
O operador bit a bit OR não está definido para left. Digite e right. Tipo.
- ou -
left. Digite e right. O tipo não é do mesmo tipo booliano.
Exemplos
O exemplo de código a seguir mostra como criar uma expressão que representa uma operação lógica OR que avalia o segundo operando somente se o primeiro operando for avaliado como false.
// 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
Comentários
O resultado BinaryExpression tem a Method propriedade definida como o método de implementação. A propriedade Type é definida como o tipo do nó. Se o nó for levantado, as propriedades IsLifted e IsLiftedToNull serão ambas true. Caso contrário, elas serão false. A propriedade Conversion é null.
As informações a seguir descrevem o método de implementação, o tipo de nó e se um nó tem comparação de precisão.
Implementando método
As regras a seguir determinam o método de implementação para a operação:
Se a Type propriedade de um
leftourightrepresenta um tipo definido pelo usuário que sobrecarrega o operador bit a bitOR, o MethodInfo que representa esse método é o método de implementação.Observação
O operador condicional
ORnão pode ser sobrecarregado em C# ou Visual Basic. No entanto, o operador condicionalORé avaliado usando o operador bit a bitOR. Portanto, uma sobrecarga definida pelo usuário do operador bit a bitORpode ser o método de implementação para esse tipo de nó.Caso contrário, se
left. Digite eright. Tipo são tipos boolianos, o método de implementação énull.
Tipo de nó e levantado versus não-levantado
Se o método de implementação não for null:
Se
left.Type eright.Type forem atribuíveis aos tipos de argumentos correspondentes do método de implementação, o nó não terá comparação de precisão. O tipo do nó é o tipo de retorno do método de implementação.Se as duas condições a seguir forem atendidas, o nó terá comparação de precisão e o tipo do nó será o tipo anulável que corresponde ao tipo de retorno do método de implementação:
left. Digite eright. Tipos são tipos de valor dos quais pelo menos um é anulável e os tipos não anuláveis correspondentes são iguais aos tipos de argumento correspondentes do método de implementação.O tipo de retorno do método de implementação é um tipo de valor não anulável.
Se o método de implementação for null:
left. Digite eright. O tipo é do mesmo tipo booliano.Se
left. Digite eright. O tipo não é anulável, o nó não é levantado. O tipo do nó é o tipo de resultado do operador condicionalORpredefinido.Se
left. Digite eright. O tipo é anulável, o nó é levantado. O tipo do nó é o tipo anulável que corresponde ao tipo de resultado do operador condicionalORpredefinido.
Aplica-se a
OrElse(Expression, Expression, MethodInfo)
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
Cria um BinaryExpression que representa uma operação condicional OR que avalia o segundo operando somente se o primeiro operando for avaliado como 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
Parâmetros
- left
- Expression
Um Expression para definir a Left propriedade igual a.
- right
- Expression
Um Expression para definir a Right propriedade igual a.
- method
- MethodInfo
A MethodInfo para definir a Method propriedade igual a.
Retornos
Um BinaryExpression que tem a NodeType propriedade igual e OrElse a Left, Righte Method propriedades definidas para os valores especificados.
Exceções
left ou right é null.
method não null é e o método que ele representa retorna void, não static é (Shared no Visual Basic) ou não usa exatamente dois argumentos.
method é null e o operador bit a bit OR não está definido para left. Digite e right. Tipo.
- ou -
method é null e left. Digite e right. O tipo não é do mesmo tipo booliano.
Comentários
O resultado BinaryExpression tem a Method propriedade definida como o método de implementação. A propriedade Type é definida como o tipo do nó. Se o nó for levantado, as propriedades IsLifted e IsLiftedToNull serão ambas true. Caso contrário, elas serão false. A propriedade Conversion é null.
As informações a seguir descrevem o método de implementação, o tipo de nó e se um nó tem comparação de precisão.
Implementando método
As regras a seguir determinam o método de implementação para a operação:
Se
methodnãonullestiver e representar um método não nulo,static(Sharedno Visual Basic) que usa dois argumentos, é o método de implementação para o nó.Caso contrário, se a Type propriedade de um
leftourightrepresenta um tipo definido pelo usuário que sobrecarrega o operador bit a bitOR, o MethodInfo que representa esse método é o método de implementação.Observação
O operador condicional
ORnão pode ser sobrecarregado em C# ou Visual Basic. No entanto, o operador condicionalORé avaliado usando o operador bit a bitOR. Portanto, uma sobrecarga definida pelo usuário do operador bit a bitORpode ser o método de implementação para esse tipo de nó.Caso contrário, se
left. Digite eright. Tipo são tipos boolianos, o método de implementação énull.
Tipo de nó e levantado versus não-levantado
Se o método de implementação não for null:
Se
left.Type eright.Type forem atribuíveis aos tipos de argumentos correspondentes do método de implementação, o nó não terá comparação de precisão. O tipo do nó é o tipo de retorno do método de implementação.Se as duas condições a seguir forem atendidas, o nó terá comparação de precisão e o tipo do nó será o tipo anulável que corresponde ao tipo de retorno do método de implementação:
left. Digite eright. Tipos são tipos de valor dos quais pelo menos um é anulável e os tipos não anuláveis correspondentes são iguais aos tipos de argumento correspondentes do método de implementação.O tipo de retorno do método de implementação é um tipo de valor não anulável.
Se o método de implementação for null:
left. Digite eright. O tipo é do mesmo tipo booliano.Se
left. Digite eright. O tipo não é anulável, o nó não é levantado. O tipo do nó é o tipo de resultado do operador condicionalORpredefinido.Se
left. Digite eright. O tipo é anulável, o nó é levantado. O tipo do nó é o tipo anulável que corresponde ao tipo de resultado do operador condicionalORpredefinido.