我想从命令行读取参数并将其存储到两个数组中。数组之间的分隔将以“ cut”表示。
示例:a.out andy bob charlie ned cut艾米·索菲·安娜
array1将是{andy,bob,charlie,ned}
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];
}
对于第二个数组,我得到了整个数组的第一个值(amy)的重复。我在做什么错了?
首先,有没有更好(更有效)的方法来做到这一点?
答案 0 :(得分:1)
注释中指出了几个问题:
在第三个循环中,代码使用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]);
}
在使用命令行运行时
./a.out andy bob charlie ned cut amy sophie anna
此代码的输出是
argv1[0] = 'andy'
argv1[1] = 'bob'
argv1[2] = 'charlie'
argv1[3] = 'ned'
argv2[0] = 'amy'
argv2[1] = 'sophie'
argv2[2] = 'anna'