Heim >Backend-Entwicklung >C++ >Wie konvertiert man effizient zwischen einem Byte und acht booleschen Werten?

Wie konvertiert man effizient zwischen einem Byte und acht booleschen Werten?

Linda Hamilton
Linda HamiltonOriginal
2024-12-12 11:38:08472Durchsuche

How to Efficiently Convert Between a Byte and Eight Boolean Values?

Erstellen eines Bytes aus booleschen Werten und umgekehrt

Problem:

Sie haben acht Boolesche Variablen und der Wunsch, sie in einem einzigen Byte zusammenzuführen. Umgekehrt möchten Sie ein Byte in acht verschiedene boolesche Werte dekodieren.

Lösung:

Auf die harte Tour:

unsigned char ToByte(bool b[8])
{
    unsigned char c = 0;
    for (int i = 0; i < 8; ++i)
        if (b[i])
            c |= 1 << i;
    return c;
}

void FromByte(unsigned char c, bool b[8])
{
    for (int i = 0; i < 8; ++i)
        b[i] = (c & (1 << i)) != 0;
}

Cooler Weg:

struct Bits
{
    unsigned b0 : 1, b1 : 1, b2 : 1, b3 : 1, b4 : 1, b5 : 1, b6 : 1, b7 : 1;
};

union CBits
{
    Bits bits;
    unsigned char byte;
};

Zuweisen zu einem Gewerkschaftsmitglied und liest von einem anderen vor. Beachten Sie, dass die Reihenfolge der Bits in Bits durch die Implementierung definiert ist.

Achtung:

Die Verwendung von Gewerkschaften auf diese Weise ist in ISO C99 genau definiert und wird von einigen C unterstützt Compiler, aber es ist undefiniertes Verhalten in ISO C. Verwenden Sie memcpy oder std::bit_cast für portables Typ-Wortspiel in C 20.

Das obige ist der detaillierte Inhalt vonWie konvertiert man effizient zwischen einem Byte und acht booleschen Werten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn