在一行中打印十六进制数组的所有元素

问题描述 投票:0回答:3

我在C char arr[100]中有一个数组,其中每个元素都可以包含任意十六进制值(偶数为0)。我想以某种方式能够在一行中打印这个数组,例如:

arr[0] = 0x11
arr[1] = 0x00
...
arr[99] = 0x22

输出应该是:

0x11 0x00 ..... 0x22

如果我使用printf()%s,它将停在0.我不想使用for循环使用%x逐个打印每个字符。由于我正在研究的系统,我对可以使用的API有所限制。它不允许printf()。它有一个函数print(),它在每次打印后添加一个新行,但接受像%x, %s, %d这样的格式字符串,如printf()

如何实现这一要求?

c arrays hex
3个回答
2
投票

您可以使用sprintf复制到缓冲区,然后打印缓冲区

#include <stdio.h>

int main(void)
{
    char arr[] = { 0x11, 0x00, 0x22, 0xFF };

    int count = sizeof(arr);

    //each element needs 5 bytes
    char *buf = malloc(5 * count + 1);

    for(int i = 0; i < count; i++)
        sprintf(buf + i * 5, "0x%02X ", arr[i] & 0xFF);

    //optional: remove the last blank space
    buf[5 * count - 1] = 0;

    printf("[%s]\n", buf);//or whichever print function available

    return 0;
}

2
投票

您可以设计自己的函数来首先构造一个字符串,然后立即打印它。你可以这样做:

void print_array(char arr[], int len) {
    if(len <= 0){
        print("");
        return;
    }
    char output[len*5];
    int i;
    for(i=0;i<len;i++) {
        output[i*5]='0';
        output[i*5+1]='x';
        int upper = (unsigned char)arr[i] / 16;
        int lower = (unsigned char)arr[i] % 16;
        output[i*5+2] = upper < 10?(upper + '0'):(upper-10+'a');
        output[i*5+3] = lower < 10?(lower + '0'):(lower-10+'a');
        output[i*5+4] = ' ';
    }
    output[i*5-1]=0;
    print("%s", output);
}

这显然会对字符宽度和编码做出一些假设。但您可以根据目标进行调整。

这是一个有效的Demo


-1
投票

到目前为止最简单的方法就是使用递归。实际上,通过仅使用main函数并将索引声明为全局变量,可以进一步压缩下面的程序。

#include <stidio.h>
//declare your array and its size as a global varaible
int arrSize = 5;
unsigned char arr[5] = {0x00, 0x11, 0x1F, 0x33, 0x34};

void recursion(int i) {
    if(i == 0){
        printf("0x%x0 ", arr[i]);
   }else{
       printf("0x%x ", arr[i]);
   }

   if(i < arrSize -1){ //at index i, if i is less than the length of your array
       i += 1;
       recursion(i); //then recurse to the next index
  }else{
       printf("\n");
  }
}

int main() {
    recursion(0); //call your recursive function in main()
}
© www.soinside.com 2019 - 2024. All rights reserved.