簡體   English   中英

如何在C中獲取變量的最低有效字節

[英]How can I get the least significant byte of a variable in C

我正在嘗試編寫一個C函數,它將打印一個由x的最不重要字節和y的剩余字節組成的字。 例如,如果x = 0x89ABCDEF且y = 0x76543210,這應該給出0x765432EF,但是如何?

為了操縱數據類型中的特定位(或字節),您應該使用逐位運算符。

基本的逐位運算符是| (或),&(和),^(異或)和〜(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組,看看hex如何轉換為二進制。

現在,我們需要取消設置除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

現在,使用“或”操作組合我們的結果:(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

花些時間熟悉這些操作,你不應該有任何麻煩。 另外,確保學習其他按位運算符(<<,>>,&=,| =等)

你試過這個嗎?

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));
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM