1

所以就像标题中所说的那样,我正在尝试将十六进制转换为二进制。但我一直面临的问题是,给定的值是 uint32_t 类型。到目前为止,我已经从 uint32_t 转换为 uint8_t,这样每个 uint8_t 变量都包含原始十六进制值的 8 位。在下面显示的代码中,我已成功将十六进制转换为二进制。但现在我无法以某种格式打印它。

    The Format is:
    1101 1110 1010 1101 1011 1110 1110 1111
    ---0 1010 1101 1011 1110 1110 1111
    --01 1011 1110 1110 1111


    void convert(uint32_t value,bool bits[],int length)
    {
          uint8_t a0,a1,a2,a3;
          int i,c,k,j;
          a0 = value;
          a1 = value >> 8;
          a2 = value >> 16;
          a3 = value >> 24;
          for(i=0,c=7;i<=7,c>=0;i++,c--)
          {
                k = a3>>c;
                if(k&1)
                   bits[i] = true;
                else
                   bits[i] = false;
          }
          for(i=8,c=7;i<=15,c>=0;i++,c--)
          {
               k = a2>>c;
               if(k&1)
                  bits[i] = true;
               else
                  bits[i] = false;
           } 
          for(i=16,c=7;i<=23,c>=0;i++,c--)
          {
                k = a1>>c;
               if(k&1)
                   bits[i] = true;
               else
                   bits[i] = false;
          }
          for(i=24,c=7;i<=31,c>=0;i++,c--)
          {
                k = a0>>c;
                if(k&1)
                    bits[i] = true;
                else
                    bits[i] = false;
          }
          for(i=0;i<32;i=i+4)
          {
               for(j=i;j<i+4;j++)
               {
                    printf("%d",bits[j]);
               }
               printf(" ");
           }
     }
     void printBits(bool *bits,int length)
     {
          int len =32,i,j;
          int y = len-length-3;
          printf("\n");
          for(i=0,j=y;i<32,j<32;i++,j++)
          {
            // Trying to come up with some idea
          }
     }
     int main( int argc, const char * argv[] )
     {
            uint32_t value = 0xDEADBEEFL;
            bool     bits[32];
            int len;              
            for (  len = 32; len > 0; len -= 7 )
            {
                 convert (value, bits, len );
                 printBits (bits, len);
            }
            return 0;
     }

尽管我认为主要思想是每次迭代时 32 位中的 len 必须转换为二进制并打印,但我无法将这个想法合并到我的代码中。所以我决定转换整个十六进制数字并尝试只打印需要的内容。

4

2 回答 2

1

你为一件事移动得太远了......i正在 8..1 应该去 7..0 (并且i应该像所有循环计数器一样,一个int. 如果它像你一样没有签名,你将永远不会< 0 以停止循环)。此外,您将 32 位值解包错误:

a0 = (value >> 24) & 0xFF;
a1 = (value >> 16) & 0xFF;
a2 = (value >> 8) & 0xFF;
a3 = value & 0xFF;
于 2015-04-09T19:56:24.150 回答
0

这里有一些解决方案!!!

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>

void toBinary(uint8_t a)
{
    uint8_t i;

    for(i=0x80;i!=0;i>>=1)
        printf("%c",(a&i)?'1':'0'); 
}

void ul32toBinary(uint32_t a)
{
    uint32_t i;

    for(i=0x80000000;i!=0;i>>=1)
        printf("%c",(a&i)?'1':'0'); 
}

int main(void)
{
    uint32_t k=0xDEADBEEF;

    uint8_t *x;

    int i;

    printf("Converting 0xCC:\t");
    toBinary(0xCC); puts("");   

    printf("Converting 0xF1:\t");
    toBinary(0xF1); puts("");

    printf("Converting 0x%08X:\t",k);
    ul32toBinary(k);puts("");   

    printf("Converting 0x%08X:\t",k);
    x=(char *)&k;   
    //This is valid on little endian CPUs as Intel are!
    for(i=3;i>=0;i--) {
        toBinary(*(x+i));
        printf(" ");            
    }
    puts("");

    return 0;
}

这是这段代码的输出!

Converting 0xCC:    11001100
Converting 0xF1:    11110001
Converting 0xDEADBEEF:  11011110101011011011111011101111
Converting 0xDEADBEEF:  11011110 10101101 10111110 11101111 

要使您指示为 EXPECTED 的输出,您必须稍微修改上面代码中的函数 toBinary()。请记住,一个字节是 8 位,而不是 4 位!要获得您想要的格式,只需在正确的位置插入一个“if”并写一个空格...提示是:if (i==0x10) {} ... !!!

晚安 :)

以下代码是在两个 4 位的半字节中打印一个字节的代码:

void toBinary2(uint8_t a)
{
    uint8_t i;

    for(i=0x80;i!=0;i>>=1) {
        printf("%c",(a&i)?'1':'0');
        if (i==0x10)
            printf(" ");
    }
}
于 2015-04-10T23:09:00.700 回答