std::bitset<N>::operator&=,|=,^=,~
From cppreference.com
 
 
 
 
 
 C++ 
 Feature test macros (C++20)
 Concepts library (C++20)
 Metaprogramming library (C++11)
 Ranges library (C++20)
 Filesystem library (C++17)
 Concurrency support library (C++11)
 Execution control library (C++26)
Utilities library 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
  
 
 
 Type support (basic types, RTTI)
 Library feature-test macros (C++20)
(C++11)
(C++20)
(C++26)
(C++20)
 Coroutine support (C++20)
 Contract support (C++26)
(C++20)(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
  (C++20)(C++20)(C++20)
  (C++20)(C++20)(C++20)
 General utilities
 Relational operators (deprecated in C++20)
(C++20)(C++20)(C++20)
  (C++20)(C++20)(C++20)
(C++20)
 Swap and type operations 
 Common vocabulary types
std::bitset 
 
 
 
 
(until C++20)
bitset::operator&=bitset::operator|=bitset::operator^=bitset::operator~
(C++11)
(C++11)
bitset& operator&=( const bitset& other );
 (1)
 (noexcept since C++11) (constexpr since C++23)
bitset& operator|=( const bitset& other );
 (2)
 (noexcept since C++11) (constexpr since C++23)
bitset& operator^=( const bitset& other );
 (3)
 (noexcept since C++11) (constexpr since C++23)
bitset operator~() const;
 (4)
 (noexcept since C++11) (constexpr since C++23)
Performs binary AND, OR, XOR and NOT.
1) Sets the bits to the result of binary AND on corresponding pairs of bits of *this and other.
2) Sets the bits to the result of binary OR on corresponding pairs of bits of *this and other.
3) Sets the bits to the result of binary XOR on corresponding pairs of bits of *this and other.
4) Returns a temporary copy of *this with all bits flipped (binary NOT).
Note that &=, |=, and ^= are only defined for bitsets of the same size N.
Contents
[edit] Parameters
 other
 -
 another bitset
[edit] Return value
1-3) *this
4) std::bitset <N>(*this).flip()
[edit] Example
Run this 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"; }
Output:
0000000000001001 (i = 4) 0000000010011001 (i = 3) 0000100110011001 (i = 2) 1001100110011001 (i = 1) 0110011001100110 (~dest)