Namespaces
Variants

std:: countr_one

From cppreference.net
Utilities library
Definiert im Header <bit>
template < class T >
constexpr int countr_one ( T x ) noexcept ;
(seit C++20)

Gibt die Anzahl der aufeinanderfolgenden 1 Bits im Wert von x zurück, beginnend vom niedrigstwertigen Bit ("rechts").

Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn T ein vorzeichenloser Ganzzahltyp ist (also unsigned char , unsigned short , unsigned int , unsigned long , unsigned long long oder ein erweiterter vorzeichenloser Ganzzahltyp).

Inhaltsverzeichnis

Parameter

x - Wert eines vorzeichenlosen Ganzzahltyps

Rückgabewert

Die Anzahl der aufeinanderfolgenden 1 Bits im Wert von x , beginnend vom niedrigstwertigen Bit.

Hinweise

Feature-Test Makro Wert Std Feature
__cpp_lib_bitops 201907L (C++20) Bitoperationen

Beispiel

#include <bit>
#include <bitset>
#include <cstdint>
#include <iostream>
int main()
{
    for (const std::uint8_t i : {0, 0b11111111, 0b11111110, 0b11100011})
        std::cout << "countr_one( " << std::bitset<8>(i) << " ) = "
                  << std::countr_one(i) << '\n';
}

Ausgabe:

countr_one( 00000000 ) = 0
countr_one( 11111111 ) = 8
countr_one( 11111110 ) = 0
countr_one( 11100011 ) = 2

Siehe auch

zählt die Anzahl der aufeinanderfolgenden 0 Bits, beginnend vom höchstwertigen Bit
(Funktions-Template)
(C++20)
zählt die Anzahl der aufeinanderfolgenden 1 Bits, beginnend vom höchstwertigen Bit
(Funktions-Template)
zählt die Anzahl der aufeinanderfolgenden 0 Bits, beginnend vom niedrigstwertigen Bit
(Funktions-Template)
(C++20)
zählt die Anzahl der 1 Bits in einer vorzeichenlosen Ganzzahl
(Funktions-Template)
prüft, ob eine Zahl eine ganzzahlige Potenz von 2 ist
(Funktions-Template)
gibt die Anzahl der auf true gesetzten Bits zurück
(öffentliche Elementfunktion von std::bitset<N> )
prüft, ob alle, mindestens eines oder keine Bits auf true gesetzt sind
(öffentliche Elementfunktion von std::bitset<N> )