Expression.OrElse Expression.OrElse Expression.OrElse Expression.OrElse Method

定義

1 番目のオペランドが BinaryExpression に評価された場合にのみ 2 番目のオペランドを評価する条件付き OR 演算を表す false を作成します。Creates a BinaryExpression that represents a conditional OR operation that evaluates the second operand only if the first operator evaluates to false.

オーバーロード

OrElse(Expression, Expression) OrElse(Expression, Expression) OrElse(Expression, Expression) OrElse(Expression, Expression)

1 番目のオペランドが BinaryExpression に評価された場合にのみ 2 番目のオペランドを評価する条件付き OR 演算を表す false を作成します。Creates a BinaryExpression that represents a conditional OR operation that evaluates the second operand only if the first operand evaluates to false.

OrElse(Expression, Expression, MethodInfo) OrElse(Expression, Expression, MethodInfo) OrElse(Expression, Expression, MethodInfo) OrElse(Expression, Expression, MethodInfo)

1 番目のオペランドが BinaryExpression に評価された場合にのみ 2 番目のオペランドを評価する条件付き OR 演算を表す false を作成します。Creates a BinaryExpression that represents a conditional OR operation that evaluates the second operand only if the first operand evaluates to false.

OrElse(Expression, Expression) OrElse(Expression, Expression) OrElse(Expression, Expression) OrElse(Expression, Expression)

1 番目のオペランドが BinaryExpression に評価された場合にのみ 2 番目のオペランドを評価する条件付き OR 演算を表す false を作成します。Creates a BinaryExpression that represents a conditional OR operation that evaluates the second operand only if the first operand evaluates to 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

パラメーター

left
Expression Expression Expression Expression

Expression プロパティを等しく設定する LeftAn Expression to set the Left property equal to.

right
Expression Expression Expression Expression

Expression プロパティを等しく設定する RightAn Expression to set the Right property equal to.

戻り値

BinaryExpression と等しい NodeType プロパティと、指定した値に設定された OrElse プロパティおよび Left プロパティを含む RightA BinaryExpression that has the NodeType property equal to OrElse and the Left and Right properties set to the specified values.

例外

left または rightnull です。left or right is null.

ビットごとの OR 演算子は、left.Type および right.Type に対して定義されていません。The bitwise OR operator is not defined for left.Type and right.Type.

または-or- left.Type と right.Type は同じブール型ではありません。left.Type and right.Type are not the same Boolean type.

次のコード例は、論理積を表す式を作成する方法を示しています。OR操作に最初のオペランドが評価された場合にのみ 2 番目のオペランドを評価するfalseします。The following code example shows how to create an expression that represents a logical OR operation that evaluates the second operand only if the first operand evaluates to 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

注釈

その結果、BinaryExpressionが、Methodプロパティ メソッドの実装に設定します。The resulting BinaryExpression has the Method property set to the implementing method. Typeプロパティが、ノードの種類に設定します。The Type property is set to the type of the node. ノードがリフトされた場合、IsLiftedIsLiftedToNullプロパティが両方ともtrueします。If the node is lifted, the IsLifted and IsLiftedToNull properties are both true. それ以外の場合はfalseします。Otherwise, they are false. Conversion プロパティが null である。The Conversion property is null.

次の情報は、メソッドの実装をノードの種類を説明し、ノードがリフトされたかどうか。The following information describes the implementing method, the node type, and whether a node is lifted.

メソッドを実装します。Implementing Method

次の規則は、操作のメソッドの実装を決定します。The following rules determine the implementing method for the operation:

  • 場合、Typeいずれかのプロパティleftまたはright演算子をオーバー ロードするユーザー定義型を表しますOR演算子、MethodInfoメソッドがメソッドの実装を表します。If the Type property of either left or right represents a user-defined type that overloads the bitwise OR operator, the MethodInfo that represents that method is the implementing method.

    注意

    条件付きORc# または Visual Basic の演算子をオーバー ロードできません。The conditional OR operator cannot be overloaded in C# or Visual Basic. ただし、条件付きOR演算子はビット演算を使用して評価OR演算子。However, the conditional OR operator is evaluated by using the bitwise OR operator. そのため、ユーザー定義のオーバー ロードをビットごとのOR演算子は、このノード型のメソッドの実装を指定できます。Thus, a user-defined overload of the bitwise OR operator can be the implementing method for this node type.

  • の場合leftします。型とrightします。型がブール型、メソッドの実装はnullします。Otherwise, if left.Type and right.Type are Boolean types, the implementing method is null.

ノードの種類かいないか無効になるとNode Type and Lifted versus Non-Lifted

メソッドの実装がない場合null:If the implementing method is not null:

  • 場合leftします。型とrightします。型のメソッドの実装の対応する引数の型に割り当てることが、ノードがリフトされていません。If left.Type and right.Type are assignable to the corresponding argument types of the implementing method, the node is not lifted. ノードの型は、実装メソッドの戻り値の型です。The type of the node is the return type of the implementing method.

  • 次の 2 つの条件が満たされている場合は、ノードがリフトし、ノードの型は、実装メソッドの戻り値の型に対応する null 許容型。If the following two conditions are satisfied, the node is lifted and the type of the node is the nullable type that corresponds to the return type of the implementing method:

    • left.型とrightします。種類は、両方が値型を少なくとも 1 つが null 許容型と対応する null 非許容の型がメソッドの実装の対応する引数の型と等しいです。left.Type and right.Type are both value types of which at least one is nullable, and the corresponding non-nullable types are equal to the corresponding argument types of the implementing method.

    • 実装メソッドの戻り値の型は、null 非許容値型です。The return type of the implementing method is a non-nullable value type.

メソッドの実装がある場合null:If the implementing method is null:

  • left.型とrightします。種類は、同じブール型です。left.Type and right.Type are the same Boolean type.

  • 場合leftします。型とrightします。型が null 非許容には、ノードがリフトされていません。If left.Type and right.Type are non-nullable, the node is not lifted. ノードの型は、定義済みの条件式の結果型OR演算子。The type of the node is the result type of the predefined conditional OR operator.

  • 場合leftします。型とrightします。型が null 許容には、ノードがリフトされました。If left.Type and right.Type are nullable, the node is lifted. ノードの型は、定義済みの条件式の結果型に対応する null 許容型OR演算子。The type of the node is the nullable type that corresponds to the result type of the predefined conditional OR operator.

OrElse(Expression, Expression, MethodInfo) OrElse(Expression, Expression, MethodInfo) OrElse(Expression, Expression, MethodInfo) OrElse(Expression, Expression, MethodInfo)

1 番目のオペランドが BinaryExpression に評価された場合にのみ 2 番目のオペランドを評価する条件付き OR 演算を表す false を作成します。Creates a BinaryExpression that represents a conditional OR operation that evaluates the second operand only if the first operand evaluates to 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);
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

パラメーター

left
Expression Expression Expression Expression

Expression プロパティを等しく設定する LeftAn Expression to set the Left property equal to.

right
Expression Expression Expression Expression

Expression プロパティを等しく設定する RightAn Expression to set the Right property equal to.

method
MethodInfo MethodInfo MethodInfo MethodInfo

MethodInfo プロパティを等しく設定する MethodA MethodInfo to set the Method property equal to.

戻り値

BinaryExpression と等しい NodeType プロパティと、指定した値に設定された OrElseLeft、および Right の各プロパティを含む MethodA BinaryExpression that has the NodeType property equal to OrElse and the Left, Right, and Method properties set to the specified values.

例外

left または rightnull です。left or right is null.

methodnull ではなく、それを表すメソッドは void を返し、static (Visual Basic では Shared) ではなく、またはちょうど 2 つの引数を受け取りません。method is not null and the method it represents returns void, is not static (Shared in Visual Basic), or does not take exactly two arguments.

methodnull で、left.Type および right.Type にはビット処理 OR 演算子が定義されていません。method is null and the bitwise OR operator is not defined for left.Type and right.Type.

または-or- methodnull で、left.Type と right.Type は同じブール型ではありません。method is null and left.Type and right.Type are not the same Boolean type.

注釈

その結果、BinaryExpressionが、Methodプロパティ メソッドの実装に設定します。The resulting BinaryExpression has the Method property set to the implementing method. Typeプロパティが、ノードの種類に設定します。The Type property is set to the type of the node. ノードがリフトされた場合、IsLiftedIsLiftedToNullプロパティが両方ともtrueします。If the node is lifted, the IsLifted and IsLiftedToNull properties are both true. それ以外の場合はfalseします。Otherwise, they are false. Conversion プロパティが null である。The Conversion property is null.

次の情報は、メソッドの実装をノードの種類を説明し、ノードがリフトされたかどうか。The following information describes the implementing method, the node type, and whether a node is lifted.

メソッドを実装します。Implementing Method

次の規則は、操作のメソッドの実装を決定します。The following rules determine the implementing method for the operation:

  • 場合methodでないnullあり、void、以外を表しますstatic(Shared Visual Basic で) 2 つの引数を受け取るメソッドは、ノードのメソッドの実装。If method is not null and it represents a non-void, static (Shared in Visual Basic) method that takes two arguments, it is the implementing method for the node.

  • の場合、Typeいずれかのプロパティleftまたはright演算子をオーバー ロードするユーザー定義型を表しますOR演算子、MethodInfoメソッドがメソッドの実装を表します。Otherwise, if the Type property of either left or right represents a user-defined type that overloads the bitwise OR operator, the MethodInfo that represents that method is the implementing method.

    注意

    条件付きORc# または Visual Basic の演算子をオーバー ロードできません。The conditional OR operator cannot be overloaded in C# or Visual Basic. ただし、条件付きOR演算子はビット演算を使用して評価OR演算子。However, the conditional OR operator is evaluated by using the bitwise OR operator. そのため、ユーザー定義のオーバー ロードをビットごとのOR演算子は、このノード型のメソッドの実装を指定できます。Thus, a user-defined overload of the bitwise OR operator can be the implementing method for this node type.

  • の場合leftします。型とrightします。型がブール型、メソッドの実装はnullします。Otherwise, if left.Type and right.Type are Boolean types, the implementing method is null.

ノードの種類かいないか無効になるとNode Type and Lifted versus Non-Lifted

メソッドの実装がない場合null:If the implementing method is not null:

  • 場合leftします。型とrightします。型のメソッドの実装の対応する引数の型に割り当てることが、ノードがリフトされていません。If left.Type and right.Type are assignable to the corresponding argument types of the implementing method, the node is not lifted. ノードの型は、実装メソッドの戻り値の型です。The type of the node is the return type of the implementing method.

  • 次の 2 つの条件が満たされている場合は、ノードがリフトし、ノードの型は、実装メソッドの戻り値の型に対応する null 許容型。If the following two conditions are satisfied, the node is lifted and the type of the node is the nullable type that corresponds to the return type of the implementing method:

    • left.型とrightします。種類は、両方が値型を少なくとも 1 つが null 許容型と対応する null 非許容の型がメソッドの実装の対応する引数の型と等しいです。left.Type and right.Type are both value types of which at least one is nullable, and the corresponding non-nullable types are equal to the corresponding argument types of the implementing method.

    • 実装メソッドの戻り値の型は、null 非許容値型です。The return type of the implementing method is a non-nullable value type.

メソッドの実装がある場合null:If the implementing method is null:

  • left.型とrightします。種類は、同じブール型です。left.Type and right.Type are the same Boolean type.

  • 場合leftします。型とrightします。型が null 非許容には、ノードがリフトされていません。If left.Type and right.Type are non-nullable, the node is not lifted. ノードの型は、定義済みの条件式の結果型OR演算子。The type of the node is the result type of the predefined conditional OR operator.

  • 場合leftします。型とrightします。型が null 許容には、ノードがリフトされました。If left.Type and right.Type are nullable, the node is lifted. ノードの型は、定義済みの条件式の結果型に対応する null 許容型OR演算子。The type of the node is the nullable type that corresponds to the result type of the predefined conditional OR operator.

適用対象