operator^
Obtiene OR exclusiva bit a bit (XOR) entre los elementos correspondientes de dos valarrays igualmente ordenados o entre un valarray y un valor especificado del tipo de elemento.
template<class Type>
valarray<Type> operator^(
const valarray<Type>& _Left,
const valarray<Type>& _Right
);
template<class Type>
valarray<Type> operator^(
const valarray<Type>& _Left,
const Type& _Right
);
template<class Type>
valarray<Type> operator^(
const Type& _Left,
const valarray<Type>& _Right
);
Parámetros
_Left
El primero de los dos valarrays cuyos elementos respectivos son combinarse con XOR bit a bit o un valor especificado del tipo de elemento es bit a bit combinado con cada elemento de un valarray._Right
El segundo de los dos valarrays cuyos elementos respectivos son combinarse con XOR bit a bit o un valor especificado del tipo de elemento es bit a bit combinado con cada elemento de un valarray.
Valor devuelto
un valarray cuyos elementos son la combinación elemento-sabia de la operación bit a bit de XOR de _Left y de _Right.
Comentarios
Una operación bit a bit sólo se puede utilizar para manipular los bits en char y los tipos de datos y las variantes de int y no en Hacer flotante, Doble, long double, void bool u otro, más tipos de datos complejos.
OR exclusiva bit a bit (XOR) tiene la semántica siguiente: Los bits especificados b1y b2, b1XOR b2son TRUE si uno de los bits es exactamente true; Falso si ambos bits son false o si ambos bits son verdaderas.
Ejemplo
// valarray_op_xor.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>
int main( )
{
using namespace std;
int i;
valarray<int> vaL ( 10 ), vaR ( 10 );
valarray<int> vaLAA ( 10 );
for ( i = 0 ; i < 10 ; i += 2 )
vaL [ i ] = 1;
for ( i = 1 ; i < 10 ; i += 2 )
vaL [ i ] = 0;
for ( i = 0 ; i < 10 ; i += 3 )
vaR [ i ] = i;
for ( i = 1 ; i < 10 ; i += 3 )
vaR [ i ] = i-1;
for ( i = 2 ; i < 10 ; i += 3 )
vaR [ i ] = i-1;
cout << "The initial Left valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaL [ i ] << " ";
cout << ")." << endl;
cout << "The initial Right valarray is: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaR [ i ] << " ";
cout << ")." << endl;
vaLAA = ( vaL ^ vaR );
cout << "The element-by-element result of "
<< "the bitwise XOR operator^ is the\n valarray: ( ";
for ( i = 0 ; i < 10 ; i++ )
cout << vaLAA [ i ] << " ";
cout << ")." << endl;
}
Requisitos
encabezado: <valarray>
espacio de nombres: std