将命令行参数传递给子进程并对它们进行计数
我希望父进程将参数传递给main(),并通过从argv [1]开始的管道一次一个地将它们中的字符发送到子进程,并继续执行其余参数。(一次调用write为每个角色)。
我希望子进程计算父进程发送给它的字符,并打印出从父进程收到的字符数。 子进程不应以任何方式使用main()的参数。
我究竟做错了什么? 我需要使用exec()吗?
输出不正确:
~ $ gc a03 gcc -Wall -g a03.c -o a03 ~ $ ./a03 abcd ef ghi child: counted 12 characters ~ $
这是程序..
#include #include #include #include #include int main(int argc, char *argv[]) { int length = 0; int i, count; int fdest[2]; // for pipe pid_t pid; //process IDs char buffer[BUFSIZ]; if (pipe(fdest) < 0) /* attempt to create pipe */ printf("pipe error"); if ((pid = fork()) 0) { close(fdest[0]); for(i = 1; i < argc; i++) /* write to pipe */ { write(fdest[1], argv[i], strlen(argv[1])); } wait(0); } else { /* child Process */ close(fdest[1]); for(i = 0; i < argc; i++) { length +=( strlen(argv[i])); /* get length of arguments */ } count = read(fdest[0], buffer, length); printf("\nchild: counted %d characters\n", count); } exit(0); }
你说过“子进程不应该以任何方式使用main()的参数”。 但是,我发现您的子进程正在使用argc
。 这不会打败你的限制吗?
你还说你想要“为每个角色写一个电话”。 您当前的实现使用一个调用来为每个参数写入,而不是每个字符。 这是一个错字吗? 如果没有,你会想要使用更像这样的东西:
char nul='\0', endl='\n'; for (a=1; a < argc; ++a) { for (c=0; c < strlen(argv[a]); ++c) { write(fdest[1], &argv[a][c], 1); } write(fdest[1], &nul, 1); } write(fdest[1], &endl, 1);
这将一次写入一个字符,每个参数作为以NULL结尾的字符串和最后的换行符。 换行符仅用作标记,表示不再发送数据(并且可以安全使用,因为您不会在CLI参数中传递换行符)。
子进程只需要是一个循环,逐个读取传入的字节,如果字节不是'\0'
或'\n'
,则递增计数器。 当它读取换行符时,它会突破输入处理循环并报告计数器的值。
你在这里有一个错误:
write(fdest[1], argv[i], strlen(argv[1]));
你应该使用strlen(argv[i])
,或者你告诉write()
读取argv [i]的空间并调用未定义的行为。
请注意,您只需调用一次read()。 当你调用read()时,父级可能只写了一个argv []。 或2.或其中任意数量。
问题出在这里
write(fdest[1], argv[i], strlen(argv[1]));
请注意,这是argv[1]
strlen,它应该是argv[i]
。 实际上,您在此循环中引用了argv[2]
和argv[3]
的结尾
你实际上是在编写strlen(“abcd”)* 3个字符,这是12个字符
在这里:
for(i = 1; i < argc; i++) /* write to pipe */ { write(fdest[1], argv[i], strlen(argv[1])); }
strlen(argv[1])
实际上应该是strlen(argv[i])