<bitset>
, operatory
operator &
Wykonuje bitowo AND
między dwoma zestawami bitów.
template <size_t size>
bitset<size>
operator&(
const bitset<size>& left,
const bitset<size>& right);
Parametry
Lewy
Pierwszy z dwóch zestawów bitów, których odpowiednie elementy mają być łączone z bitowym AND
.
Prawy
Druga z dwóch valarrays, których odpowiednie elementy mają być łączone z bitowym AND
.
Wartość zwracana
Zestaw bitów, którego elementy są wynikiem wykonania AND
operacji na odpowiednich elementach lewej i prawej.
Przykład
// 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<<
Wstawia tekstową reprezentację sekwencji bitów do strumienia wyjściowego.
template <class CharType, class Traits, size_t N>
basic_ostream<CharType, Traits>& operator<<(
basic_ostream<CharType, Traits>& ostr,
const bitset<N>& right);
Parametry
Prawy
Obiekt typu bitset<N> , który ma zostać wstawiony do strumienia wyjściowego jako ciąg.
Wartość zwracana
Tekstowa reprezentacja sekwencji bitów w pliku ostr
.
Uwagi
Funkcja szablonu przeciąża operator<<
funkcję , umożliwiając zapisanie zestawu bitów bez uprzedniego przekonwertowania jej na ciąg. Funkcja szablonu skutecznie wykonuje:
ostr << right.
to_string<CharType, Traits, allocator<CharType>>()
Przykład
// 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>>
Odczytuje ciąg znaków bitowych do zestawu bitów.
template <class CharType, class Traits, size_t Bits>
basic_istream<CharType, Traits>& operator>> (
basic_istream<CharType, Traits>& i_str,
bitset<N>& right);
Parametry
i_str
Ciąg wprowadzony do strumienia wejściowego, który ma zostać wstawiony do zestawu bitów.
Prawy
Zestaw bitów odbierający bity ze strumienia wejściowego.
Wartość zwracana
Funkcja szablonu zwraca i_str ciągu.
Uwagi
Funkcja szablonu przeciąża przechowywanie w zestawie bitów prawej wartości , gdzie str
jest obiektem typu basic_string< CharType, Traits, allocator< CharType > >&
wyodrębnionym z i_str.bitset(str)
operator>>
Funkcja szablonu wyodrębnia elementy z i_str i wstawia je do zestawu bitów do:
Wszystkie elementy bitowe zostały wyodrębnione ze strumienia wejściowego i przechowywane w zestawie bitów.
Bitset jest wypełniony bitami ze strumienia wejściowego.
Napotkano element wejściowy, który nie jest ani 0, ani 1.
Przykład
#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^
Wykonuje bitowo EXCLUSIVE-OR
między dwoma zestawami bitów.
template <size_t size>
bitset<size>
operator^(
const bitset<size>& left,
const bitset<size>& right);
Parametry
Lewy
Pierwszy z dwóch zestawów bitów, których odpowiednie elementy mają być łączone z bitowym EXCLUSIVE-OR
.
Prawy
Druga z dwóch valarrays, których odpowiednie elementy mają być łączone z bitowym EXCLUSIVE-OR
.
Wartość zwracana
Zestaw bitów, którego elementy są wynikiem wykonania EXCLUSIVE-OR
operacji na odpowiednich elementach lewej i prawej.
Przykład
// 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|
Wykonuje bitowo OR między dwoma bitset
obiektami.
template <size_t size>
bitset<size>
operator|(
const bitset<size>& left,
const bitset<size>& right);
Parametry
Lewy
Pierwszy z dwóch zestawów bitów, których odpowiednie elementy mają być łączone z bitowym OR
.
Prawy
Druga z dwóch valarrays, których odpowiednie elementy mają być łączone z bitowym OR
.
Wartość zwracana
Zestaw bitów, którego elementy są wynikiem wykonania OR
operacji na odpowiednich elementach lewej i prawej.
Przykład
// 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