std::bitset<N>:: operator&=,|=,^=,~
From cppreference.net
C++
Utilities library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::bitset
| Member types | ||||
| Member functions | ||||
|
(until C++20)
|
||||
| Element access | ||||
| Capacity | ||||
| Modifiers | ||||
|
bitset::operator&=
bitset::operator|=
bitset::operator^=
bitset::operator~
|
||||
| Conversions | ||||
|
(C++11)
|
||||
| Non-member functions | ||||
| Helper classes | ||||
|
(C++11)
|
||||
|
bitset
&
operator
&
=
(
const
bitset
&
other
)
;
|
(1) |
(noexcept depuis C++11)
(constexpr depuis C++23) |
|
bitset
&
operator
|
=
(
const
bitset
&
other
)
;
|
(2) |
(noexcept depuis C++11)
(constexpr depuis C++23) |
|
bitset
&
operator
^
=
(
const
bitset
&
other
)
;
|
(3) |
(noexcept depuis C++11)
(constexpr depuis C++23) |
|
bitset operator~
(
)
const
;
|
(4) |
(noexcept depuis C++11)
(constexpr depuis C++23) |
Effectue les opérations binaires AND, OR, XOR et NOT.
1)
Définit les bits comme le résultat de l'opération ET binaire sur les paires de bits correspondantes de
*
this
et
other
.
2)
Définit les bits au résultat de l'opération OU binaire sur les paires correspondantes de bits de
*
this
et
other
.
3)
Définit les bits comme le résultat du XOR binaire sur les paires correspondantes de bits de
*
this
et
other
.
4)
Retourne une copie temporaire de
*
this
avec tous les bits inversés (NOT binaire).
Notez que
&=
,
|=
, et
^=
sont uniquement définis pour des bitsets de même taille
N
.
Table des matières |
Paramètres
| autre | - | un autre bitset |
Valeur de retour
1-3)
*
this
4)
std::
bitset
<
N
>
(
*
this
)
.
flip
(
)
Exemple
Exécuter ce code
#include <bitset> #include <cstddef> #include <iostream> #include <string> int main() { const std::string pattern_str{"1001"}; std::bitset<16> pattern{pattern_str}, dest; for (std::size_t i = dest.size() / pattern_str.size(); i != 0; --i) { dest <<= pattern_str.size(); dest |= pattern; std::cout << dest << " (i = " << i << ")\n"; } std::cout << ~dest << " (~dest)\n"; }
Sortie :
0000000000001001 (i = 4) 0000000010011001 (i = 3) 0000100110011001 (i = 2) 1001100110011001 (i = 1) 0110011001100110 (~dest)
Voir aussi
|
effectue un décalage binaire vers la gauche et vers la droite
(fonction membre publique) |