operator^
2 個の均等なサイズの valarrays の対応する要素または要素型の valarray と値のビットごとの排他的 OR (XOR) を取得します。
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
);
パラメーター
_Left
それぞれの要素が valarray の各要素とビット処理演算子で結合する要素型のビットごとの XOR と組み合わせること、または指定値である 2 個の valarrays の狭い。_Right
それぞれの要素が valarray の各要素とビット処理演算子で結合する要素型のビットごとの XOR と組み合わせること、または指定値である 2 個の valarrays の 2 番目の。
戻り値
要素が _Left と _Right.の XOR 操作のビットごとの組み合わせである要素的に valarray
解説
ビットごとの演算は char のと int のデータ型とバリアントであり [float]、double、long double、voidbool またはそのほかの複雑なデータ型のビットを処理する場合にのみ使用できます。
ビットごとの排他的 OR (XOR) に次のセマンティクスを持っています: 正確ビットの 1 つが当てはまる場合は、特定のビット b1と b2、b1XORb2 はです true ; ビットが両方とも false であるか、ビットが両方とも true の場合 false。
使用例
// 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;
}
必要条件
ヘッダー: <valarray>
名前空間: std