[英]How to run program with n-command in C?
我现在已经一一编译了。 我还面临着终止进程的问题。
int main(int argc, char *argv[]) {
int n = 1;
int f = 1;
signal(SIG_ERR, sig_hand1);
signal(SIGINT, sig_hand1);
for (f; f < argc; f++){ \\create n-numberd fork.
nfork(f, argv);
}
for (n; n<argc; n++){ \\terminate the child one by one.
Rturn(n, argv);
}
return 0;
}
使用 Rturn 功能
void Rturn(int n, char *argv[]){
int status;
struct rusage usage;
struct timeval start;
struct timeval end;
wait4(-1, &status, 0, &usage);
if(WIFSIGNALED(status)==1){
char *str = strdup(signame[WTERMSIG(status)]);
printf("\nThe command %c%s%c is interrupted by the %s\n\n", '"', argv[n], '"',str);
}
else if(WEXITSTATUS(status) == 255)
printf("The program experienced an error in starting the command: %s\n\n", argv[n]);
else
printf("\nThe command %c%s%c terminated with returned status code = %d\n\n", '"', argv[n], '"', WEXITSTATUS(status));
}
和 nfork
void nfork(int n, char *argv[]){
if(fork() == 0){
printf("Process with id:%d created for the command: %s\n", getpid(), argv[n]);
fflush(stdout);
if(execlp(argv[n], argv[n], NULL) == -1){
printf("\nexeclp: %s\n\n", strerror(errno));
exit(-1);
}
}
}
我发现消息不是由进程返回,而是由循环中的 n 返回。
例如,如果我运行
./test cd fake //with command cd and "fake"
然后它会返回
monitor experienced an error in starting the command: cd
预期回报应该是这样的
monitor experienced an error in starting the command: fake
如何找到变量 n 的正确子级?
成功时, fork()
函数返回两次。 在父进程中,它的返回值是新子进程的进程ID。 在子进程中,返回值为0。通过返回给它的进程ID,父进程可以识别特定的子进程,从而等待他们,向他们发送信号等。
您的nfork()
函数目前忽略fork()
的返回值,只是检查它是否为零。 这是错误的,原因有二:
父级不区分fork()
调用的成功和失败。 它只是假设它成功了。
父级希望能够稍后将特定子级与n的相应值相关联。 各个进程由其进程 ID 标识。 只有在nfork()
中有机会将子进程 ID 与n 个值相关联,但该函数未能利用它。
有多种方法可以记录子索引和子进程 ID 之间的关联,但最简单的方法可能是创建一个数组来存储它们。 nfork()
需要填充该数组,而RTurn()
将需要从中提取要等待的PID,然后将其作为第一个参数提供给wait4()
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.