Cでビットマスクを作成する簡潔な方法はありますか?
-
29-10-2019 - |
質問
3つの32ビットジェネラコダイスタグコードで終わる3つのビットマスクを作成する必要があります(それらをx、y、zと呼びましょう)。マスクは次のようになります: ジェネラコディセタグプレ
これまでのところ私はこれを持っています: ジェネラコディセタグプレ
しかし、それは少し厄介なようです。誰かがもっと簡潔な(そして読みやすい)方法を思い付くことができますか?
解決
C99を使用している場合は、「新規」固定幅タイプを使用してください。
uint32_t x, y, z;
x = 0x01FFFFFF;
y = 0x0E000000;
z = 0xF0000000;
.
または "ugly" octal : - )を使用することができます。
.x = 000177777777; // 00 000 001 111 111 111 111 111 111 111 111
y = 001600000000; // 00 001 110 000 000 000 000 000 000 000 000
z = 036000000000; // 11 110 000 000 000 000 000 000 000 000 000
他のヒント
ジェネラコディセタグプレ
これは読みやすいですか?
unsigned intに必要な数を入力するだけです(16進表記を使用したい場合): ジェネラコディセタグプレ
所属していません StackOverflow