0

我正在编写一个 mini-shell,但在作业控制方面遇到了问题。
我无法检索主函数中的数据,甚至无法在 run_command 的底部检索数据。
我想知道如何在主目录中存储和成功检索信息。

typedef struct job{
    int num;
    pid_t pid[SIZE];
    char* name[SIZE];
    int occupied;
}
job jobs; <- the global variable

int run_command(........){
.    .......
.    .......
.    result = fork(); // generate child process
.    if ( result == 0 ){ //child process
.    .    if ( 2-pipe function is detected){ // 2 pipe
.    .    .    .......
.    .    .    .......
.    .    .    pid01 = fork(); // fork the first child ( for the first "cat" in case of "cat | cat | cat")
.    .    .    if (pid 01 == 0){
.    .    .        .....
.    .    .    }
.    .    .    else{
.    .    .    .    pid02 = fork(); // fork the second child
.    .    .    .    if (pid02 == 0){
.    .    .    .        .....
.    .    .    .    }
.    .    .    .    else{
.    .    .    .    .    pid03 = fork(); // fork the third child
.    .    .    .    .    if (pid03 == 0){
.    .    .    .    .        ....
.    .    .    .    .    }
.    .    .    .    .    else{
.    .    .    .    .    .     ....
.    .    .    .    .    .     waitpid(pid01,&status1, WUNTRACED);
.    .    .    .    .    .     waitpid(pid02,&status2, WUNTRACED);
.    .    .    .    .    .     waitpid(pid03,&status3, WUNTRACED);
.    .    .    .    .    .     if (WIFSTOPPED(status1)){
.    .    .    .    .    .         jobs.occupied = 1;
.    .    .    .    .    .         jobs.num = 3;
.    .    .    .    .    .         for () {} (a for loop to store the job, i.e. " cat | cat | cat ")
.    .    .    .    .    .         jobs.pid[0] = pid01;
.    .    .    .    .    .     }
.    .    .    .    .    .     if (WIFSTOPPED(status2)){
.    .    .    .    .    .         jobs.pid[1] = pid02;
.    .    .    .    .    .     }
.    .    .    .    .    .     if (WIFSTOPPED(status3)){
.    .    .    .    .    .         jobs.pid[2] = pid03;
.    .    .    .    .    .     }
.    .    .    .    .    }
.    .    .    .    }
.    .    .    }
.    .    }
.    .    exit(-1);
.    }
.    waitpid( result, &status, WUNTRACED);
.    if (WIDSTOPPED(status)){
.    ....
.    }
.    ( cannot retrieve jobs here already, like the variable "jobs" has been initialized again)
.    return 0;
}

int main(){
.....
.....
.....
run_command(........);
(jobs hasn't been modified after I have press ctrl-z)
return 0;
}
4

1 回答 1

0

通过 fork 创建的父进程和子进程之间不共享变量。进程之间通信的唯一方法包括:

  • 使用 Unix 域套接字交换数据
  • 在 fork 之前创建一个管道并使用它来写入/读取数据
  • 使用进程的退出状态(数据大小有限)
  • 信号的使用(数据量非常有限,实际上只有SIGUSR1和SIGUSR2可以安全使用)
于 2013-10-14T12:54:44.260 回答