将 uint8_t 十六进制值转换为二进制

标签 c binary hex bit-manipulation uint32-t

就像标题中所说的那样,我正在尝试将十六进制转换为二进制。但我一直面临的问题是,给定的值是 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 转换为二进制并打印,但我无法将该思想纳入我的代码中。所以我决定转换整个十六进制数,并尝试只打印需要的内容。

最佳答案

你在一件事上移动得太远了......i 正在 8..1 应该去 7..0(i 应该是,像所有循环计数器一样,一个 int。如果它像你拥有的那样是无符号的,你将永远不会 < 0 来停止循环)。此外,您错误地解包了 32 位值:

a0 = (value >> 24) & 0xFF;
a1 = (value >> 16) & 0xFF;
a2 = (value >> 8) & 0xFF;
a3 = value & 0xFF;

关于将 uint8_t 十六进制值转换为二进制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29547628/

相关文章:

linux - 如何将 linux 可执行文件(二进制)转换为 windows exe 文件?

python - 为什么我的 Python 读取的位数比我设置的位数多?

c# - 将文件中的十六进制添加到 List<byte>

c - GStreamer 解决了从命令行转换为 C 代码时的过滤问题

c - 我的 GLFW 窗口正在显示它后面的内容

java - 输出错误:Binary to decimal java

Ruby:用十六进制表示替换 ascii 范围内的某些字符

c - 为什么MTK只显示 'F'

c - 是否有必要调用 pthread_exit()

C 编程。尝试读写时程序崩溃