Archivo de encabezado de la biblioteca estándar <bitset>
De cppreference.com
Este archivo de encabezado es parte de la biblioteca de utilidades generales.
Incluye | |
| <string> | |
| <iosfwd> | |
Clases | |
| Implementa un array de bits de longitud constante. (plantilla de clase) | |
(C++11) |
Apoyo de generación de dispersión para std::bitset. (especialización de plantilla de clase) |
Funciones | |
| Realiza operaciones lógicas binarias en conjuntos de bits. (función) | |
| Realiza entrada y salida de flujos de conjuntos de bits. (función) | |
Sinopsis
#include <string>
#include <iosfwd> // para istream, ostream
namespace std {
template <size_t N> class bitset;
// operadores bitset:
template <size_t N>
bitset<N> operator&(const bitset<N>&, const bitset<N>&) noexcept;
template <size_t N>
bitset<N> operator|(const bitset<N>&, const bitset<N>&) noexcept;
template <size_t N>
bitset<N> operator^(const bitset<N>&, const bitset<N>&) noexcept;
template <class charT, class traits, size_t N>
basic_istream<charT, traits>&
operator>>(basic_istream<charT, traits>& is, bitset<N>& x);
template <class charT, class traits, size_t N>
basic_ostream<charT, traits>&
operator<<(basic_ostream<charT, traits>& os, const bitset<N>& x);
// Soporte para hash (resumen)
template <class T> struct hash;
template <size_t N> struct hash<bitset<N> >;
}
Clase std::bitset
template<size_t N> class bitset {
public:
// referencia bit:
class reference {
friend class bitset;
reference() noexcept;
public:
~reference() noexcept;
reference& operator=(bool x) noexcept; // para b[i] = x;
reference& operator=(const reference&) noexcept;// para b[i] = b[j];
bool operator~() const noexcept; // cambia el bit
operator bool() const noexcept; // para x = b[i];
reference& flip() noexcept; // para b[i].flip();
};
// constructores:
constexpr bitset() noexcept;
constexpr bitset(unsigned long long val) noexcept;
template<class charT, class traits, class Allocator>
explicit bitset(
const basic_string<charT,traits,Allocator>& str,
typename basic_string<charT,traits,Allocator>::size_type pos = 0,
typename basic_string<charT,traits,Allocator>::size_type n =
basic_string<charT,traits,Allocator>::npos,
charT zero = charT('0'), charT one = charT('1'));
template <class charT>
explicit bitset(
const charT* str,
typename basic_string<charT>::size_type n = basic_string<charT>::npos,
charT zero = charT('0'), charT one = charT('1'));
// operaciones bitset:
bitset<N>& operator&=(const bitset<N>& rhs) noexcept;
bitset<N>& operator|=(const bitset<N>& rhs) noexcept;
bitset<N>& operator^=(const bitset<N>& rhs) noexcept;
bitset<N>& operator<<=(size_t pos) noexcept;
bitset<N>& operator>>=(size_t pos) noexcept;
bitset<N>& set() noexcept;
bitset<N>& set(size_t pos, bool val = true);
bitset<N>& reset() noexcept;
bitset<N>& reset(size_t pos);
bitset<N> operator~() const noexcept;
bitset<N>& flip() noexcept;
bitset<N>& flip(size_t pos);
// acceso a elementos:
constexpr bool operator[](size_t pos) const; // para b[i];
reference operator[](size_t pos); // para b[i];
unsigned long to_ulong() const;
unsigned long long to_ullong() const;
template <class charT = char,
class traits = char_traits<charT>,
class Allocator = allocator<charT> >
basic_string<charT, traits, Allocator>
to_string(charT zero = charT('0'), charT one = charT('1')) const;
size_t count() const noexcept;
constexpr size_t size() noexcept;
bool operator==(const bitset<N>& rhs) const noexcept;
bool operator!=(const bitset<N>& rhs) const noexcept;
bool test(size_t pos) const;
bool all() const noexcept;
bool any() const noexcept;
bool none() const noexcept;
bitset<N> operator<<(size_t pos) const noexcept;
bitset<N> operator>>(size_t pos) const noexcept;
};