将命令行输入字符串解析为char数组

时间:2012-07-27 23:11:34

标签: c command-line-arguments

我正在尝试编写一个C程序,其中命令行参数的输入格式为0x1234aabb

这绝对是作为char *[]的程序出现的。

现在,我想以char a[]={0x12, 0x34, 0xaa, 0xbb}

的形式存储此输入

请帮忙。

3 个答案:

答案 0 :(得分:0)

我首先要做的是使用strtoul和16(十六进制)的基本参数来解析字符串为整数。保证unsigned long的大小至少为32位,所以如果你的所有数字都有8个十六进制数字(4个字节),那么它应该是一个合适的类型。

一旦你有你的号码,比特移位和按位和数字4次,以提取构成数字的4个字节中的每一个。这是一个例子:

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

#define NUM_BYTES 4

int main(void)
{
   char *input = "0x1234aabb";
   unsigned long num = strtoul(input, NULL /* TODO: error checking */, 16);
   unsigned char bytes[NUM_BYTES];
   unsigned i;

   printf("The number is: 0x%lx\n", num);

   /* bytes[0] = LSB, bytes[NUM_BYTES - 1] = MSB */
   for (i = 0; i < NUM_BYTES; i++) {
      bytes[i] = (num >> 8*i) & 0xFF; /* byte = 8 bits, 0xFF = max byte value */
      printf("Byte %u: 0x%x\n", i+1, bytes[i]);
   }

   return 0;
}

输出:

The number is: 0x1234aabb
Byte 1: 0xbb
Byte 2: 0xaa
Byte 3: 0x34
Byte 4: 0x12

答案 1 :(得分:0)

如果您知道字符串始终是固定长度(例如,您的示例中为10个字符),则可以将字符串拆分为四个相等的部分,每三个字符长(两个用于数字,一个用于终结符),以及然后在每个部分使用strtoul。如果参数少于十个字符,则只填写相关部分并将另一部分保留为"00"

答案 2 :(得分:0)

尝试这样的方法来解析任意长度的输入:

#include <stdio.h>

int main(int argc, char** argv)
{
    char *input;
    int len;
    int num;
    char *a;
    int i;
    int tmp;

    if (argv < 2)
    {
        printf("No input specified!\n");
        return 0;
    }

    input = argv[1]; // "0x1234aabb"
    if (strncmpi(input, "0x", 2) != 0)
    {
        printf("Bad input!\n");
        return 0;
    }

    printf("Input: %s\n", input);

    input += 2;
    len = strlen(input);
    num = (len / 2) + (len % 2);
    if (num < 1)
    {
        printf("Bad input!\n");
        return 0;
    }

    printf("Number of bytes: %d\n", num);

    a = (char*) calloc(num, sizeof(char));
    if (a == NULL)
    {
        printf("Cannot allocate memory for bytes!\n");
        return 0;
    }

    for (i = 0; i < num; ++i)
    {
        if (sscanf(input, "%2x", &tmp) != 1)
        {
            printf("Byte %d: Illegal byte value '%02s'\n", i+1, input);
            break;
        }

        a[i] = (char) tmp;
        printf("Byte %d: 0x%02x\n", i+1, a[i]);

        input += 2;
    }

    free(a);

    return 0;
}