-1

我开发的这段代码只是为了解决我正在开发的另一个大型程序中遇到的问题。

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <cstring> 
#include <cstdlib> 
#include <sys/types.h>
#include <sys/wait.h>
#include <errno.h>
#include <limits.h>
#include <string>
#include <iostream>

using namespace std;
void processLine (char []);
void readLine(char []);

const int LIMIT = 512;
int main(int argc, char *argv[])
{
    char oneLine[LINE_MAX];
    readLine(oneLine);
    
        
    return 0;
}
void readLine(char line[])
{
    processLine(line);
    

 //Otherstuff
 ------------

}
void processLine(char line[])
{
    
    pid_t process;
    int child_status;

    string input;
    cout << "Input: ";
    cin >> input;

    
        process = fork();
        if(process == 0)
        { // do nothing
        }
        else 
        {
                        //parent
                    if(input == "quit")
            {
                printf("Quit command found ! \nExiting ");
                    
                for(int i = 0;i < 3;i++)
                {
                    printf(".");
                    fflush(stdout);
                    sleep(1);
                    
                }
            
                printf("\n");
                    exit(0);            
            }
            else
            {
                wait(&child_status);
            }
        }
    
}

我的目标很简单,当用户输入退出时。

我只会显示

找到退出命令

退出...

这三个点中的每一个之间都有一秒钟的延迟。

但是我得到的输出是

找到退出命令

退出。其他的东西 ..

但是,似乎发生的是父进程返回,然后从调用函数执行其他内容,然后继续打印其他两个点。我将如何避免父进程这样做?

4

1 回答 1

0

像这样使用 waitpid():

pid_t childPid;  
childPid = fork();
...
int returnStatus;    
waitpid(childPid, &returnStatus, 0);  // Parent process waits here for child to terminate.

在这里使用它

if(childPid == 0)  // fork succeeded 
{   
   // Do something   
   exit(0); 
}
else  // Main (parent) process after fork succeeds 
{    
    int returnStatus;    
    waitpid(childPid, &returnStatus, 0);
}
于 2016-02-07T17:05:16.143 回答