0

私が開発している別の大規模なプログラムで発生した問題に対処するためだけに開発したこのコードがあります。

#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);
    printf("Annoying line\n");
}
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);
            }
        }
    
}

私の目標は単純です。ユーザーが終了すると入力します。

そのまま表示します

終了コマンドが見つかりました

終了しています...

そして、これら 3 つのドットのそれぞれの間には 1 秒の遅延があります。

しかし、私が得る出力は

終了コマンドが見つかりました

終了します。迷惑なライン..

呼び出し関数からのものであり、端末に出力される番ではないのに、最初のドットの後にこの迷惑な行が出力されるのはどうしてだろうか????

何か案は。これを修正するのに10時間費やしました

4

1 に答える 1

1

子プロセスでは、// do nothingフォールスルーして戻りmain()、行を印刷します。 fork()実行を継続する 2 つのコピーを作成します。多くの場合、子供はexec()すぐに何かを実行するために呼び出しますが (返されることはありません)、あなたはそのようなことをしていません。

于 2016-02-07T07:07:56.880 に答える