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!