如何在C中合并3个二进制数据?

时间:2019-04-17 10:43:20

标签: c bitwise-operators

我正在尝试将以下位序列组合为一个变量,然后将其转换为十进制。

*b1=0b001011;
*b2=0b101010;
*b3=0b0001;

位顺序应如下;

newBin = 0001101010001011(newBin = b3b2b1)

我尝试了以下代码段,但无法获得正确的十进制等效值。

int combine=(*b1<<16)|(*b2<<10)|*b3;

当我打印联合收割机时,它给出4097,但应该给出6795。

我将不胜感激。

重要说明:我已经尝试过Combine =(* b1 << 12)|(* b2 << 6)| * b3;并合并=(* b3 << 16)|(* b2 << 10)| * b1;结果都一样; 4097。

在完整程序中,我正在解析32位值。我从下面的链接中使用了“食指”给出的代码。

How do I get bit-by-bit data from an integer value in C?

以下是我版本的完整代码;

int *get_bits(int n, int bitswanted){
  int *bits = malloc(sizeof(int) * bitswanted);

  int k;
  for(k=0; k<bitswanted; k++){
    int mask =  1 << k;
    int masked_n = n & mask;
    int thebit = masked_n >> k;
    bits[k] = thebit;
  }

  return bits;
}

int main()
{
    long r=0b0010110100111110000010110110101010000001;
    int i;
    int byte1,byte2,byte3,byte4,byte5;
    //int *Lbits,*Mbits,*Hbits;
    int bw6=6,bw4=4;

    byte1 = (r>>32) & 0xFF;
    byte2 = (r>>24) & 0xFF;
    byte3 = (r>>16) & 0xFF;
    byte4 = (r>>8) & 0xFF;
    byte5 = (r>>0) & 0xFF;

   int *Lbits=get_bits(byte3,bw6);
   int *Mbits=get_bits(byte4,bw6);
   int *Hbits=get_bits(byte5,bw4);

   int combine=(Hbits<<12)|(&Mbits<<6)|Lbits;



  for(i=bw6-1; i>=0;i--)
  {
    printf("%d", Lbits[i]);
  }
  printf("\n");

  for(i=bw6-1; i>=0;i--)
  {
    printf("%d", Mbits[i]);
  }
  printf("\n");

  for(i=bw4-1; i>=0;i--)
  {
    printf("%d", Hbits[i]);
  }
  printf("\n");

  printf("%d",combine);
}

3 个答案:

答案 0 :(得分:0)

  1. 您移动得太多,最终在数字之间留下零
  2. 请勿使用int,您可能要为此使用unsigned long long intuint64_t Int的大小未在C标准中指定。
  3. 我尝试在python中运行您的代码,结果为763905,所以您可能还有一些此处未显示的错误。
  4. 您为什么将它们用作指针?这似乎与您在此处提出的问题无关。

答案 1 :(得分:0)

因此,当br3是MSB时,应该是:

int combine=(*b3<<12)|(*b2<<6)|*b1;


  0b0001     (1d)  * 4096  (12 left shift)  = 4096
 +0b101010   (42d) *   64  (6 left shift)   = 2688
 +0b001011   (11d) *    1                   =   11
  _________________________________________________
                                               6795

答案 2 :(得分:0)

您的函数get_bits不会返回int或类似的东西,您可以通过移位和按位OR进行组合。它返回一个int数组,其中每个元素都包含单个位的值。

(可以通过逐位处理这些位来根据需要组合来自这些数组的数据,但是此概念还有其他陷阱,因为您必须确保不要访问超出范围的动态分配内存)

这是程序的修改版本,可与unsigned int而不是int数组一起使用。

#include <stdio.h>

unsigned int get_bits(unsigned int n, int bitswanted){
    return n & ((1<<bitswanted)-1);
}

int main()
{
    unsigned long r=0b0010110100111110000010110110101010000001;
    int i;
    int byte1,byte2,byte3,byte4,byte5;

    int bw6=6,bw4=4;

    byte1 = (r>>32) & 0xFF;
    byte2 = (r>>24) & 0xFF;
    byte3 = (r>>16) & 0xFF;
    byte4 = (r>>8) & 0xFF;
    byte5 = (r>>0) & 0xFF;

   int Lbits=get_bits(byte3,bw6);
   int Mbits=get_bits(byte4,bw6);
   int Hbits=get_bits(byte5,bw4);

   int combine=(Hbits<<12)|(Mbits<<6)|Lbits;

   printf("%d\n",combine);
}

程序将打印结果6795

请参阅https://ideone.com/44pjjF