두 개의 명령을 묻는 간단한 파이프 프로그램을 작성한 후 프로그램을 bash에 cmd1 | cmd2
으로 입력 한 것처럼 실행합니다. 그런 다음 명령 중 하나가 quit
이 될 때까지 반복하고 묻습니다.wait (NULL)로 인해 실행이 중지되는 것 같습니다.
이미이 정도 작성했습니다 : 나는 그것을 실행하고 입력하면
#include<iostream>
#include<string>
#include<sys/types.h>
#include<sys/wait.h>
#include<string.h>
#include<unistd.h>
#include<stdlib.h>
#include<stdio.h>
#include<signal.h>
using namespace std;
int main(int argc, char *argv[])
{
int pid1, pid2, errchk;
int pip[2];
char cmd1[128];
char cmd2[128];
int i = 0;
int status;
errchk = pipe(pip);//make pipe
if(errchk == -1)//check for error in pipe
{
perror("pipe");
exit(1);
}
while(i<3)
{
i++;
//Enter commands here
cout<<"Enter cmd1: ";
cin>>cmd1;
cout<<"Enter cmd2: ";
cin>>cmd2;
//if a command is quit... quit
if(strcmp(cmd1,"quit")==0 || strcmp(cmd2,"quit") == 0)
{
cout<<"Quitting...\n";
exit(1);
}
pid1 = fork();
cout<<"first fork makes pids: "<<pid1<<endl;
if(pid1 < 0)
{
perror("fork");
exit(1);
}
else if(pid1 == 0) //MAIN CHILD
{
cout<<"In main child with pid: "<<pid1<<endl;
pid2 = fork();
cout<<"second fork makes pids: "<<pid2<<endl;
if(pid2 == 0)//SUB CHILD 2 to run cmd2
{
cout<<"In child of second fork"<<endl;
close(0);
close(pip[1]);
dup(pip[0]);
execvp(cmd2,argv);//execute command2 and die
}
else if(pid2 > 0)//SUB CHILD 1 to run cmd1
{
cout<<"In parent of second fork"<<endl;
close(1);
close(pip[0]);
dup(pip[1]);
execvp(cmd1,argv);//execute command1 and die
}
}
else if(pid1 > 0) //MAIN PARENT
{
wait(NULL);//wait for cmd1
wait(NULL);//wait for cmd2
cout<<"DONE executing"<<endl; //keep going
}
}
return 0;
}
ls
및 wc
내가 얻을 출력은 다음과 같습니다
Enter cmd1: ls
Enter cmd2: wc
first fork makes pids: 5785
first fork makes pids: 0
In main child with pid: 0
second fork makes pids: 5786
In parent of second fork
second fork makes pids: 0
In child of second fork
DONE executing
5 5 54
내가 가진 가장 큰 문제는 I Done executing
은 ls|wc
뒤에 오는 것이 좋습니다. wait(NULL)
이 작동하지 않지만 확실하지 않다고 생각합니다.
알려 주시기 바랍니다. 고마워요.
손주를 기다릴 수 없습니다. child1은 child2를 기다려야 만한다. –
악의적 인 사용자가 공백없이 긴 문자열을 입력하면 정의되지 않은 동작이 발생하여'cin >> cmd1;'과'cin >> cmd2;'행이 오버플로 할 수있다. 이것은 C++이므로'char [128]'가 아니라'std :: string'을 사용하십시오. – aschepler
execvp는 문자열과 작동하지 않으므로 char을 사용해야합니다. – sshulgan