在Linux下創建子進程:
pid_t pid;
if(( pid = fork()) == -1 ) //創建子進程
{
exit(0); //創建進程失敗,退出程序
} else if(pid == 0) { //子進程空間
char *args[]={FileMonitor, "-fp", lmonitorList[num].lm_strDirectory, NULL};
if(execve(FileMonitor, args, NULL)< 0) { //在子進程中調用FileMonitor進程
printf("execve ./wisFileMonitor -fp %s failed in the child process!/n", lmonitorList[num].lm_strDirectory);
CREATE_THREAD(StartMonitorThread, (THREAD_PARAM) num);
}
} else { //父進程空間
lmonitorList[num].lm_pid = pid;
lmonitorList[num].lm_bstop=false;
}
如果在創建子進程時,沒有出現任何錯誤,fork函數將返回兩次,一次在父進程中,另一次在子進程中。fork函數將新創建的子進程ID返回給父進程,並將0返回給子進程。
在Windows下創建子進程較常用到的API就是CreateProcess,可以通過以下的方式啟動一個新進程:
STARTUPINFO si = {0};
PROCESS_INFORMATION pi = {0};
si.cb = sizeof(STARTUPINFO); //結構體大小
GetStartupInfo(&si); //初始化結構
si.wShowWindow = SW_HIDE; //新進程不顯示窗口
si.dwFlags = STARTF_USESHOWWINDOW; //令si.wShowWindow生效
//關鍵步驟,CreateProcess函數參數意義請查閱MSDN
if (!CreateProcess( NULL, //可執行文件名,為NULL時,通過szCmdLine提供
szCmdLine, //命令行參數
NULL, //指向一個SECURITY_ATTRIBUTES結構體,這個結構體決定是否返回的句柄可以被子進程繼承。
//如果lpProcessAttributes參數為空(NULL),那麼句柄不能被繼承。
NULL, //指向一個SECURITY_ATTRIBUTES結構體,這個結構體決定是否返回的句柄可以被子進程繼承。
//如果lpThreadAttributes參數為空(NULL),那麼句柄不能被繼承。
FALSE, //指示新進程是否從調用進程處繼承了句柄
NULL, //指定附加的、用來控制優先類和進程的創建的標志
NULL, //指向一個新進程的環境塊。如果此參數為空,新進程使用調用進程的環境
NULL, //子進程的工作路徑,當進程名為相對路徑時,必須填寫
&si, //指向一個用於決定新進程的主窗體如何顯示的STARTUPINFO結構體
&pi)) //指向一個用來接收新進程信息的PROCESS_INFORMATION結構體
{
return false;
}
WaitForSingleObject(pi.hProcess,INFINITE); //等待子進程結束
CloseHandle(pi.hThread); //關閉新進程的主線程
CloseHandle(pi.hProcess); //關閉新進程