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 é avaliado como false
.
Sobrecargas
OrElse(Expression, Expression) |
Cria um BinaryExpression que representa uma operação |
OrElse(Expression, Expression, MethodInfo) |
Cria um BinaryExpression que representa uma operação |
OrElse(Expression, Expression)
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
Cria um BinaryExpression que representa uma operação OR
condicional que avalia o segundo operando somente se o primeiro operando é 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 propriedade Left igual a ele.
- right
- Expression
Um Expression para definir a propriedade Right igual a ele.
Retornos
Um BinaryExpression que tem a propriedade NodeType igual a OrElse e as propriedades Left e Right definidas com os valores especificados.
Exceções
left
ou right
é null
.
O operador OR
bit a bit não está definido para left
.Type e right
.Type.
- ou -
left
.Type e right
.Type não sã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 resultante BinaryExpression tem a Method propriedade definida como o método de implementação. A Type propriedade é definida como o tipo do nó. Se o nó for levantado, as IsLifted propriedades e IsLiftedToNull serão true
ambas . Caso contrário, eles 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ó é levantado.
Implementando método
As seguintes regras determinam o método de implementação para a operação:
Se a Type propriedade de
left
ouright
representa 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
OR
nã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 bitOR
pode 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 versão com comparação de precisão x sem comparação de precisão
Se o método de implementação não null
for :
Se
left
. Digite eright
. O tipo é atribuível aos tipos de argumento correspondentes do método de implementação, o nó não é levantado. 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ó será levantado 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
. Tipo 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 permite valor nulo, o nó não é levantado. O tipo do nó é o tipo de resultado do operador condicionalOR
predefinido.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 condicionalOR
predefinido.
Aplica-se a
OrElse(Expression, Expression, MethodInfo)
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
- Origem:
- BinaryExpression.cs
Cria um BinaryExpression que representa uma operação OR
condicional que avalia o segundo operando somente se o primeiro operando é 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 propriedade Left igual a ele.
- right
- Expression
Um Expression para definir a propriedade Right igual a ele.
- method
- MethodInfo
Um MethodInfo para definir a propriedade Method igual a ele.
Retornos
Um BinaryExpression que tem a propriedade NodeType igual a OrElse e as propriedades Left, Right e Method definidas com 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 tem exatamente dois argumentos.
method
é null
e o operador OR
bit a bit não é definido para left
.Type e right
.Type.
- ou -
method
é null
e Type.left
e Type.right
não são do mesmo tipo booliano.
Comentários
O resultante BinaryExpression tem a Method propriedade definida como o método de implementação. A Type propriedade é definida como o tipo do nó. Se o nó for levantado, as IsLifted propriedades e IsLiftedToNull serão true
ambas . Caso contrário, eles 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ó é levantado.
Implementando método
As seguintes regras determinam o método de implementação para a operação:
Se
method
nãonull
for e representar um método não nulo,static
(Shared
no Visual Basic) que usa dois argumentos, é o método de implementação para o nó.Caso contrário, se a Type propriedade de
left
ouright
representa 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
OR
nã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 bitOR
pode 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 versão com comparação de precisão x sem comparação de precisão
Se o método de implementação não null
for :
Se
left
. Digite eright
. O tipo é atribuível aos tipos de argumento correspondentes do método de implementação, o nó não é levantado. 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ó será levantado 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
. Tipo 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 permite valor nulo, o nó não é levantado. O tipo do nó é o tipo de resultado do operador condicionalOR
predefinido.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 condicionalOR
predefinido.