Este artículo se tradujo automáticamente. Para ver el artículo en inglés, active la casilla Inglés. Además, puede mostrar el texto en inglés en una ventana emergente si mueve el puntero del mouse sobre el texto.
Traducción
Inglés

Método Expression.ExclusiveOr (Expression, Expression, MethodInfo)

 

Crea un objeto BinaryExpression que representa una operación XOR bit a bit, usando op_ExclusiveOr para los tipos definidos por el usuario. Se puede especificar el método de implementación.

Espacio de nombres:   System.Linq.Expressions
Ensamblado:  System.Core (en System.Core.dll)

public static BinaryExpression ExclusiveOr(
	Expression left,
	Expression right,
	MethodInfo method
)

Parámetros

left
Type: System.Linq.Expressions.Expression

Objeto Expression en el que se va a establecer la propiedad Left.

right
Type: System.Linq.Expressions.Expression

Objeto Expression en el que se va a establecer la propiedad Right.

method
Type: System.Reflection.MethodInfo

MethodInfo en el que se va a establecer la propiedad Method.

Valor devuelto

Type: System.Linq.Expressions.BinaryExpression

BinaryExpression cuya propiedad NodeType es ExclusiveOr y Left, Right y Method se establecen en los valores especificados.

Exception Condition
ArgumentNullException

El valor de left o right es null.

ArgumentException

method no es null y el método que representa devuelve void, no es static (Shared en Visual Basic), o no toma exactamente dos argumentos.

InvalidOperationException

method es null y el operador XOR no está definido para left.Type y right.Type.

The resulting T:System.Linq.Expressions.BinaryExpression has the P:System.Linq.Expressions.BinaryExpression.Method property set to the implementing method. The P:System.Linq.Expressions.Expression.Type property is set to the type of the node. If the node is lifted, the P:System.Linq.Expressions.BinaryExpression.IsLifted and P:System.Linq.Expressions.BinaryExpression.IsLiftedToNull properties are both true. Otherwise, they are false. The P:System.Linq.Expressions.BinaryExpression.Conversion property is null.

The following information describes the implementing method, the node type, and whether a node is lifted.

The following rules determine the chosen implementing method for the operation:

  • 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.

  • Otherwise, if the P:System.Linq.Expressions.Expression.Type property of either left or right represents a user-defined type that overloads the XOR operator, the T:System.Reflection.MethodInfo that represents that method is the implementing method.

  • Otherwise, if left.Type and right.Type are integral or Boolean types, the implementing method is null.

If the implementing method is not null:

  • 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.

  • 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.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.

    • The return type of the implementing method is a non-nullable value type.

If the implementing method is null:

  • If left.Type and right.Type are both non-nullable, the node is not lifted. The type of the node is the result type of the predefined XOR operator.

  • If left.Type and right.Type are both nullable, the node is lifted. The type of the node is the nullable type that corresponds to the result type of the predefined XOR operator.

Plataforma universal de Windows
Disponible desde 8
.NET Framework
Disponible desde 3.5
Biblioteca de clases portable
Se admite en: plataformas portátiles de .NET
Silverlight
Disponible desde 2.0
Windows Phone Silverlight
Disponible desde 7.0
Windows Phone
Disponible desde 8.1
Volver al principio
Mostrar: