Operadores <bitset>
operator&
Executa um AND
bit a bit entre dois bitsets.
template <size_t size>
bitset<size>
operator&(
const bitset<size>& left,
const bitset<size>& right);
Parâmetros
esquerda
O primeiro dos dois bitsets cujos respectivos elementos devem ser combinados com o AND
bit a bit.
direita
A segunda das duas valarrays cujos respectivos elementos devem ser combinados com o AND
bit a bit.
Valor de retorno
Um bitset cujos elementos são o resultado da execução da operação AND
nos elementos correspondentes de left e right.
Exemplo
// bitset_and.cpp
// compile with: /EHsc
#include <bitset>
#include <iostream>
#include <string>
using namespace std;
int main()
{
bitset<4> b1 ( string("0101") );
bitset<4> b2 ( string("0011") );
bitset<4> b3 = b1 & b2;
cout << "bitset 1: " << b1 << endl;
cout << "bitset 2: " << b2 << endl;
cout << "bitset 3: " << b3 << endl;
}
bitset 1: 0101
bitset 2: 0011
bitset 3: 0001
operator<<
Insere uma representação de texto da sequência de bits no fluxo de saída.
template <class CharType, class Traits, size_t N>
basic_ostream<CharType, Traits>& operator<<(
basic_ostream<CharType, Traits>& ostr,
const bitset<N>& right);
Parâmetros
direita
Um objeto do tipo bitset<N> que deve ser inserido no fluxo de saída como uma cadeia de caracteres.
Valor de retorno
Uma representação de texto da sequência de bits em ostr
.
Comentários
As função de modelo sobrecarrega operator<<
, permitindo que um bitset seja gravado primeiro ser convertido em uma cadeia de caracteres. A função de modelo é executada efetivamente:
ostr << right.
to_string<CharType, Traits, allocator<CharType>>()
Exemplo
// bitset_op_insert.cpp
// compile with: /EHsc
#include <bitset>
#include <iostream>
#include <string>
int main( )
{
using namespace std;
bitset<5> b1 ( 9 );
// bitset inserted into output stream directly
cout << "The ordered set of bits in the bitset<5> b1(9)"
<< "\n can be output with the overloaded << as: ( "
<< b1 << " )" << endl;
// Compare converting bitset to a string before
// inserting it into the output stream
string s1;
s1 = b1.template to_string<char,
char_traits<char>, allocator<char> >( );
cout << "The string returned from the bitset b1"
<< "\n by the member function to_string( ) is: "
<< s1 << "." << endl;
}
operator>>
Lê uma cadeia de caracteres de bit em um bitset.
template <class CharType, class Traits, size_t Bits>
basic_istream<CharType, Traits>& operator>> (
basic_istream<CharType, Traits>& i_str,
bitset<N>& right);
Parâmetros
i_str
A cadeia de caracteres que é inserida no fluxo de entrada a ser inserido no bitset.
direita
O bitset que está recebendo os bits do fluxo de entrada.
Valor de retorno
A função de modelo retorna a cadeia de caracteres i_str.
Comentários
A função de modelo sobrecarrega operator>>
para armazenar no bitset right o valor bitset(str)
, em que str
é um objeto do tipo basic_string< CharType, Traits, allocator< CharType > >&
extraído de i_str.
A função de modelo extrai elementos de i_str e insere-os em um bitset até:
Todos os elementos do bit terem sido extraídos do fluxo de entrada e armazenados no bitset.
O bitset ser preenchido com bits do fluxo de entrada.
Ser localizado um elemento de entrada que não seja 0 nem 1.
Exemplo
#include <bitset>
#include <iostream>
#include <string>
using namespace std;
int main()
{
bitset<5> b1;
cout << "Enter string of (0 or 1) bits for input into bitset<5>.\n"
<< "Try bit string of length less than or equal to 5,\n"
<< " (for example: 10110): ";
cin >> b1;
cout << "The ordered set of bits entered from the "
<< "keyboard\n has been input into bitset<5> b1 as: ( "
<< b1 << " )" << endl;
// Truncation due to longer string of bits than length of bitset
bitset<2> b3;
cout << "Enter string of bits (0 or 1) for input into bitset<2>.\n"
<< " Try bit string of length greater than 2,\n"
<< " (for example: 1011): ";
cin >> b3;
cout << "The ordered set of bits entered from the "
<< "keyboard\n has been input into bitset<2> b3 as: ( "
<< b3 << " )" << endl;
// Flushing the input stream
char buf[100];
cin.getline(&buf[0], 99);
// Truncation with non-bit value
bitset<5> b2;
cout << "Enter a string for input into bitset<5>.\n"
<< " that contains a character than is NOT a 0 or a 1,\n "
<< " (for example: 10k01): ";
cin >> b2;
cout << "The string entered from the keyboard\n"
<< " has been input into bitset<5> b2 as: ( "
<< b2 << " )" << endl;
}
operator^
Executa um EXCLUSIVE-OR
bit a bit entre dois bitsets.
template <size_t size>
bitset<size>
operator^(
const bitset<size>& left,
const bitset<size>& right);
Parâmetros
esquerda
O primeiro dos dois bitsets cujos respectivos elementos devem ser combinados com o EXCLUSIVE-OR
bit a bit.
direita
A segunda das duas valarrays cujos respectivos elementos devem ser combinados com o EXCLUSIVE-OR
bit a bit.
Valor de retorno
Um bitset cujos elementos são o resultado da execução da operação EXCLUSIVE-OR
nos elementos correspondentes de left e right.
Exemplo
// bitset_xor.cpp
// compile with: /EHsc
#include <bitset>
#include <iostream>
#include <string>
using namespace std;
int main()
{
bitset<4> b1 ( string("0101") );
bitset<4> b2 ( string("0011") );
bitset<4> b3 = b1 ^ b2;
cout << "bitset 1: " << b1 << endl;
cout << "bitset 2: " << b2 << endl;
cout << "bitset 3: " << b3 << endl;
}
bitset 1: 0101
bitset 2: 0011
bitset 3: 0110
operator|
Executa um OR bit a bit entre dois objetos bitset
.
template <size_t size>
bitset<size>
operator|(
const bitset<size>& left,
const bitset<size>& right);
Parâmetros
esquerda
O primeiro dos dois bitsets cujos respectivos elementos devem ser combinados com o OR
bit a bit.
direita
A segunda das duas valarrays cujos respectivos elementos devem ser combinados com o OR
bit a bit.
Valor de retorno
Um bitset cujos elementos são o resultado da execução da operação OR
nos elementos correspondentes de left e right.
Exemplo
// bitset_or.cpp
// compile with: /EHsc
#include <bitset>
#include <iostream>
#include <string>
using namespace std;
int main()
{
bitset<4> b1 ( string("0101") );
bitset<4> b2 ( string("0011") );
bitset<4> b3 = b1 | b2;
cout << "bitset 1: " << b1 << endl;
cout << "bitset 2: " << b2 << endl;
cout << "bitset 3: " << b3 << endl;
}
bitset 1: 0101
bitset 2: 0011
bitset 3: 0111