Поделиться через


valarray::operator~

Унарный оператор побитового оператора, который получает значения NOT каждого элемента в valarray.

valarray<Type> operator~( ) const;

Возвращаемое значение

Valarray логических значений, побитовые NOT значений элементов valarray операнда.

Заметки

Битовую операцию можно использовать только для управления биты в char и типы данных и вариантах int и не на плавающее, double, long,doublevoid, bool или другой, более сложных типов данных.

Побитовый оператор NOT имеет одну и ту же таблицу правды, как логическое значение NOT, но применяется к типу данных на уровне отдельных битов. Данный тип B, ~b значение true, если B значение и значение, если B имеет значение true. Логическое оператор!NOT применяется на уровне элемента, понижение уровня все ненулевое значение как true, а результат valarray логических значений. Побитовый оператор NOT operator~, напротив, может привести к valarray значений, отличных от 0 или 1 в зависимости от результатов битовой операции.

Пример

// valarray_op_bitnot.cpp
// compile with: /EHsc
#include <valarray>
#include <iostream>

int main( )
{
   using namespace std;
   int i;

   valarray<unsigned short int> vaL1 ( 10 );
   valarray<unsigned short int> vaNOT1 ( 10 );
   for ( i = 0 ; i < 10 ; i += 2 )
      vaL1 [ i ] =  i;
   for ( i = 1 ; i < 10 ; i += 2 )
      vaL1 [ i ] =  5*i;
   
   cout << "The initial valarray <unsigned short int> is:  ( ";
      for ( i = 0 ; i < 10 ; i++ )
         cout << vaL1 [ i ] << " ";
   cout << ")." << endl;

   vaNOT1 = ~vaL1;
   cout << "The element-by-element result of "
        << "the bitwise NOT operator~ is the\n valarray: ( ";
      for ( i = 0 ; i < 10 ; i++ )
         cout << vaNOT1 [ i ] << " ";
   cout << ")." << endl << endl;

   valarray<int> vaL2 ( 10 );
   valarray<int> vaNOT2 ( 10 );
   for ( i = 0 ; i < 10 ; i += 2 )
      vaL2 [ i ] =  i;
   for ( i = 1 ; i < 10 ; i += 2 )
      vaL2 [ i ] =  -2 * i;
   
   cout << "The initial valarray <int> is:  ( ";
      for ( i = 0 ; i < 10 ; i++ )
         cout << vaL2 [ i ] << " ";
   cout << ")." << endl;

   vaNOT2 = ~vaL2;
   cout << "The element-by-element result of "
        << "the bitwise NOT operator~ is the\n valarray: ( ";
      for ( i = 0 ; i < 10 ; i++ )
         cout << vaNOT2 [ i ] << " ";
   cout << ")." << endl;

   // The negative numbers are represented using
   // the two's complement approach, so adding one
   // to the flipped bits returns the negative elements
   vaNOT2 = vaNOT2 + 1;
   cout << "The element-by-element result of "
        << "adding one\n is the negative of the "
        << "original elements the\n valarray: ( ";
      for ( i = 0 ; i < 10 ; i++ )
         cout << vaNOT2 [ i ] << " ";
   cout << ")." << endl;
}
  

Требования

Заголовок:<valarray>

Пространство имен: std

См. также

Ссылки

Класс valarray