Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/c/56.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将argv[]存储到由特殊字符串(C)划分的两个数组中_C - Fatal编程技术网

将argv[]存储到由特殊字符串(C)划分的两个数组中

将argv[]存储到由特殊字符串(C)划分的两个数组中,c,C,我想从命令行读取参数并将它们存储到两个数组中。阵列之间的间隔将用“切割”表示 例句:安迪·鲍勃·查理·内德剪下了艾米·索菲·安娜 第一排是{安迪,鲍勃,查理,内德} array2将是{amy,sophie,anna} 我找到了单词“cut”的argc。然后,我为第一个数组运行了一个从0到该索引的循环。第二个数组有问题 int cutindex, i; for(i=1; i<argc; i++) { if(strcmp("cut", argv[i]) == 0){ cutind

我想从命令行读取参数并将它们存储到两个数组中。阵列之间的间隔将用“切割”表示

例句:安迪·鲍勃·查理·内德剪下了艾米·索菲·安娜

第一排是{安迪,鲍勃,查理,内德}

array2将是{amy,sophie,anna}

我找到了单词“cut”的argc。然后,我为第一个数组运行了一个从0到该索引的循环。第二个数组有问题

int cutindex, i;

for(i=1; i<argc; i++) {
  if(strcmp("cut", argv[i]) == 0){
    cutindex = i;
  }
}

char argv1[10];
for(i=0; i<cutindex-1; i++) {
  argv1[i] = argv[i+1];
}

char argv2[10];
for(i=0; i<argc-cutindex-1; i++) {
  argv2[i] = argv[cutindex+1];
}
int-cutindex,i;

对于(i=1;i,评论中指出了几个问题:

  • 在第三个循环中,代码使用
    cutindex+1
    索引到
    argv
    数组中。但是循环不会更改
    cutindex
    ,因此对整个数组重复“cut”(“示例中的amy”)之后的第一个参数

  • 输出数组
    argv1
    argv2
    应该是指针数组

  • 第一个问题的一个解决方案是为每个数组使用一个单独的索引,这样您就可以根据需要增加每个索引,而无需尝试用数学方法计算索引

    附加的好处是,当代码完成时,每个输出索引的最终值是相应输出数组中的元素计数

    另一个额外的好处是,您可以限制写入数组的元素数。请注意,在下面的代码中,前10个参数之后的任何参数都会被自动删除。在实际代码中,您可能希望提醒用户他们输入的参数太多

    #include <stdio.h>
    #include <string.h>
    #define MAX_ARG 10
    
    int main(int argc, char *argv[])
    {
        char *argv1[MAX_ARG];   // first array of arguments
        int n1 = 0;             // index into first array
    
        char *argv2[MAX_ARG];   // second array of arguments
        int n2 = 0;             // index into second array
    
        // copy pointers into the first array until "cut" is found
        int i;
        for (i = 1; i < argc; i++)
        {
            if (strcmp("cut", argv[i]) == 0)
                break;
            if (n1 < MAX_ARG)
                argv1[n1++] = argv[i];
        }
    
        // copy any remaining pointers into the second array
        for (i++; i < argc; i++)
        {
            if (n2 < MAX_ARG)
                argv2[n2++] = argv[i];
        }
    
        // print the arrays
        for (int i = 0; i < n1; i++)
            printf("argv1[%d] = '%s'\n", i, argv1[i]);
        putchar('\n');
        for (int i = 0; i < n2; i++)
            printf("argv2[%d] = '%s'\n", i, argv2[i]);
    }
    
    这段代码的输出是

    argv1[0] = 'andy'
    argv1[1] = 'bob'
    argv1[2] = 'charlie'
    argv1[3] = 'ned'
    
    argv2[0] = 'amy'
    argv2[1] = 'sophie'
    argv2[2] = 'anna'
    

    argv[cutindex+1];
    在第二个循环中不会更改。然后使用
    char*argv1[10]
    。指针数组这可能无关紧要,但如果使用a.out amy cut bob cut charlie cut denise cut edward
    调用程序,则拆分将发生在
    edward
    之前的
    cut
    处。也就是说,拆分是在最后一次
    cut
    处进行的。如果最后一次参数是
    cut
    ,也不是中间
    cut
    参数是否应该保留。用
    NULL
    指针(
    argv[cutindex]=NULL;
    )替换指向所选
    cut
    的指针,然后是
    char**argv1=&argv[1];char**argv2=&argv[cutindex+1];
    ,提供两个以空指针结尾的列表。这假定在此之后不需要原始参数列表。或者简单地安排将
    argv
    数组的相关子部分复制到新数组中。
    argv1[0] = 'andy'
    argv1[1] = 'bob'
    argv1[2] = 'charlie'
    argv1[3] = 'ned'
    
    argv2[0] = 'amy'
    argv2[1] = 'sophie'
    argv2[2] = 'anna'