#include<iostream>
#include<spawn.h>
#include<stdlib.h>
#include<sys/wait.h>
using namespace std;
int main(int argc,char *argv[],char *envp[])
{
pid_t c1,c2;
int ret1,ret2,val;
ret1=posix_spawn(&c1,"t.cpp",NULL,NULL,argv,envp);
ret2=posix_spawn(&c2,"t.cpp",NULL,NULL,argv,envp);
wait(&val);
wait(&val);
cout<<"\n\nChild Process 1: "<<c1;
cout<<"\n\nChild Process 2: "<<c2;
cout<<"\n\n"<<ret1;
cout<<"\n\n"<<ret2<<"\n";
}
Приведенный выше код создает 2 дочерних процесса, и каждый процесс должен выполнять t.cpp, который представляет собой простой код hello world на c ++. Но это не выполняет его. На самом деле этот код работает без создания даже t.cpp. Может кто-нибудь объяснить, почему это происходит и как выполнить t1.cpp?
Это способ создания нового процесса:
posix_spawn (&Pid, «my_exe», NULL, NULL, ARGV, envp);
где my_exe — исполняемый файл, созданный после сборки программы. В вашем случае t будет исполняемым файлом, созданным после сборки программы.