我正在编写一个使用sprintf将整数转换为字符串的程序。为了给你更多的上下文,我的程序有一个父进程,根据需要生成尽可能多的子进程来计算给定的命令行参数的总和。每个子进程都会收到2个计算参数。整个部分很简单,只是让我感到困惑的回归过程。我得到了总和,现在我需要将它们变成字符串。所以我认为这样的事情会起作用,
for(int i=1; i<10; i++) {
if (array[i] == 0) {
break;
}
temp = array[i];
sprintf(sums, "%d", temp);
argv[i]=*sums;
}
for (int i=0; i<10; i++) {
printf("argv[%d]: %s\n", i, argv[i]);
}
但是,不要获得如下所示的输出:
argv[0] = ./master
argv[1] = 3
argv[2] = 7
argv[3] = 11
argv[4] = 15
etc...
我明白了:
argv[0] = ./master
argv[1] = 15
argv[2] = 15
argv[3] = 15
argv[4] = 15
etc...
我无法弄清楚为什么最后一笔钱会重演。我有一种感觉,它与我使用sprintf的方式有关,但我花了将近一整天的时间试图解决这个问题,而且我已经合法地被卡住了。顺便说一句,我已经在我的程序顶部声明了数组
int array[10]={0};
答案 0 :(得分:0)
结合您的代码和伙伴&#39;评论,我相信这是建议的内容:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, char *argv[]) {
char number_string[128];
char *my_argv[100];
int my_argc = 0;
int array[] = { 3, 7, 11, 15, 0 };
my_argv[my_argc++] = strdup(argv[0]);
for (int i = 0; array[i] != 0; i++) {
sprintf(number_string, "%d", array[i]);
my_argv[my_argc++] = strdup(number_string);
}
for (int i = 0; i < my_argc; i++) {
printf("argv[%d]: %s\n", i, my_argv[i]);
free(my_argv[i]);
}
return 0;
}
如果由于某种原因您没有strdup()
,则可以使用malloc()
和strcpy()
执行等效操作。重复使用argv[]
并不合理,因为它的大小仅限于argc
,您甚至不会考虑这一点。
<强>输出强>
> ./master
argv[0]: ./master
argv[1]: 3
argv[2]: 7
argv[3]: 11
argv[4]: 15
>