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