我正在尝试将以下位序列组合为一个变量,然后将其转换为十进制。
*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);
}
答案 0 :(得分:0)
int
,您可能要为此使用unsigned long long int
或uint64_t
Int的大小未在C标准中指定。答案 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
。