2

x の最下位バイトと y の残りのバイトで構成される単語を出力する C 関数を作成しようとしています。たとえば、x = 0x89ABCDEF で y = 0x76543210 の場合、これは 0x765432EF になるはずですが、どうすればよいでしょうか?

4

2 に答える 2

10

データ型内の特定のビット (またはバイト) を操作するには、ビット単位の演算子を使用する必要があります。

基本的なビット単位の演算子は | です。(or)、& (and)、^ (排他的 or)、および ~ (NOT または補数) であり、論理演算子 ||、&&、および ! とは大きく異なります。

変数 x = 0x89ABCDEF および y = 0x76543210 を使用して、ソリューションをステップ実行しましょう。

まず、これらはバイナリの x と y の値です。

    x = 1000 1001 1010 1011 1100 1101 1110 1111
    y = 0111 0110 0101 0100 0011 0010 0001 0000

32 ビットを 4 つのグループに分割して、16 進数が 2 進数にどのように変換されるかを確認しました。

ここで、x の最後のバイト以外をすべて設定解除する必要があります: 操作 (x & 0xFF)

           x = 1000 1001 1010 1011 1100 1101 1110 1111
        0xFF = 0000 0000 0000 0000 0000 0000 1111 1111
    --------------------------------------------------
    x & 0xFF = 0000 0000 0000 0000 0000 0000 1110 1111

そして、y の最後のバイトだけを設定解除する必要があります: 操作 (y & ~0xFF)

              y = 0111 0110 0101 0100 0011 0010 0001 0000
          ~0xFF = 1111 1111 1111 1111 1111 1111 0000 0000 (~ flips all bits)
    -----------------------------------------------------
    (y & ~0xFF) = 0111 0110 0101 0100 0011 0010 0000 0000

ここで、「or」演算を使用して結果を結合します: (x & 0xFF) | (y & ~0xFF)

                  (x & 0xFF) = 0000 0000 0000 0000 0000 0000 1110 1111
                 (y & ~0xFF) = 0111 0110 0101 0100 0011 0010 0000 0000
    ------------------------------------------------------------------
    (x & 0xFF) | (y & ~0xFF) = 0111 0110 0101 0100 0011 0010 1110 1111
    Which in hex is------------7----6----5----4----3----2----E----F

これらの操作に慣れるまで少し時間をかけてください。問題はありません。また、他のビット演算子 (<<、>>、&=、|= など) も学習してください。

于 2012-09-12T07:28:52.620 に答える
7

これを試しましたか?

inline uint32_t combine(uint32_t x, uint32_t y) {
  return (y & 0xffffff00) | (x & 0xff);
}

例を次に示します (結果はこちらを参照してください)。

#include <inttypes.h>
#include <stdio.h>

inline uint32_t combine(uint32_t x, uint32_t y) {
  return (y & 0xffffff00) | (x & 0xff);
}

main() {
  printf("%" PRIx32 "\n", combine(0x89abcdef, 0x76543210));
}
于 2012-09-11T23:07:23.793 に答える