Expression.OrElse 方法
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
创建一个 BinaryExpression,它表示仅在第一个操作数的计算结果为 OR
时才计算第二个操作数的条件 false
运算。
重载
OrElse(Expression, Expression) |
创建一个 BinaryExpression,它表示仅在第一个操作数的计算结果为 |
OrElse(Expression, Expression, MethodInfo) |
创建一个 BinaryExpression,它表示仅在第一个操作数的计算结果为 |
OrElse(Expression, Expression)
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
创建一个 BinaryExpression,它表示仅在第一个操作数的计算结果为 OR
时才计算第二个操作数的条件 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 属性设置为与其相等的 Left。
- right
- Expression
要将 Expression 属性设置为与其相等的 Right。
返回
一个 BinaryExpression,其 NodeType 属性等于 OrElse,并且其 Left 和 Right 属性设置为指定值。
例外
left
或 right
为 null
。
没有为 left
.Type 和 right
.Type 定义按位 OR
运算符。
- 或 -
left
.Type 和 right
.Type 不是同一布尔值类型。
示例
下面的代码示例演示如何创建表示逻辑 OR
运算的表达式,该表达式仅在第一个操作数的计算结果为 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 属性设置为实现方法。 属性 Type 设置为节点的类型。 如果提升节点,则 IsLifted 和 IsLiftedToNull 属性都是 true
。 否则,它们是 false
。 Conversion 属性为 null
。
以下信息介绍了实现方法、节点类型以及节点是否提升。
实现方法
以下规则确定操作的实现方法:
Type如果 或
right
的left
属性表示重载按位OR
运算符的用户定义类型,MethodInfo则表示该方法的 是实现方法。注意
不能在 C# 或 Visual Basic 中重载条件
OR
运算符。 但是,条件OR
运算符是使用按OR
位运算符计算的。 因此,按OR
位运算符的用户定义重载可以是此节点类型的实现方法。否则为 (如果
left
为 )。键入 和right
。类型为布尔类型,实现方法是null
。
节点类型和提升与非提升
如果实现方法不是 null
:
如果
left
为 。键入 和right
。类型可分配给实现方法的相应参数类型,节点不会提升。 节点的类型是实现方法的返回类型。如果满足以下两个条件,则会提升节点,并且节点的类型是对应于实现方法的返回类型为 null 的类型:
left
.键入 和right
。类型是两个值类型,其中至少有一个可为 null,相应的不可为 null 类型等于实现方法的相应参数类型。实现方法的返回类型是不可为 null 的值类型。
如果实现方法是 null
:
left
.键入 和right
。类型是相同的布尔类型。如果
left
为 。键入 和right
。类型不可为 null,节点不会提升。 节点的类型是预定义条件OR
运算符的结果类型。如果
left
为 。键入 和right
。类型可为 null,节点被提升。 节点的类型是对应于预定义条件OR
运算符的结果类型为 null 的类型。
适用于
OrElse(Expression, Expression, MethodInfo)
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
- Source:
- BinaryExpression.cs
创建一个 BinaryExpression,它表示仅在第一个操作数的计算结果为 OR
时才计算第二个操作数的条件 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
参数
- left
- Expression
要将 Expression 属性设置为与其相等的 Left。
- right
- Expression
要将 Expression 属性设置为与其相等的 Right。
- method
- MethodInfo
要将 MethodInfo 属性设置为与其相等的 Method。
返回
一个 BinaryExpression,其 NodeType 属性等于 OrElse,并且其 Left、Right 和 Method 属性设置为指定值。
例外
left
或 right
为 null
。
method
不是 null
,它所表示的方法返回 void
,而不是 static
(Visual Basic 中为 Shared
),或者并非采用两个参数。
method
是 null
,且没有为 left
.Type 和 right
.Type 定义按位 OR
运算符。
- 或 -
method
为 null
并且 left
.Type 和 right
.Type 不是同一布尔值类型。
注解
生成的 BinaryExpression 将 Method 属性设置为实现方法。 属性 Type 设置为节点的类型。 如果提升节点,则 IsLifted 和 IsLiftedToNull 属性都是 true
。 否则,它们是 false
。 Conversion 属性为 null
。
以下信息介绍了实现方法、节点类型以及节点是否提升。
实现方法
以下规则确定操作的实现方法:
如果
method
不是null
,并且它表示非 void,static
(Shared
在 Visual Basic) 方法中采用两个参数,则它是节点的实现方法。否则,如果 Type 或
right
的left
属性表示重载按OR
位运算符的用户定义类型,MethodInfo则表示该方法的 是实现方法。注意
不能在 C# 或 Visual Basic 中重载条件
OR
运算符。 但是,条件OR
运算符是使用按OR
位运算符计算的。 因此,按OR
位运算符的用户定义重载可以是此节点类型的实现方法。否则为 (如果
left
为 )。键入 和right
。类型为布尔类型,实现方法是null
。
节点类型和提升与非提升
如果实现方法不是 null
:
如果
left
为 。键入 和right
。类型可分配给实现方法的相应参数类型,节点不会提升。 节点的类型是实现方法的返回类型。如果满足以下两个条件,则会提升节点,并且节点的类型是对应于实现方法的返回类型为 null 的类型:
left
.键入 和right
。类型是两个值类型,其中至少有一个可为 null,相应的不可为 null 类型等于实现方法的相应参数类型。实现方法的返回类型是不可为 null 的值类型。
如果实现方法是 null
:
left
.键入 和right
。类型是相同的布尔类型。如果
left
为 。键入 和right
。类型不可为 null,节点不会提升。 节点的类型是预定义条件OR
运算符的结果类型。如果
left
为 。键入 和right
。类型可为 null,节点被提升。 节点的类型是对应于预定义条件OR
运算符的结果类型为 null 的类型。