Qt GUI应用程序意外结束

时间:2012-03-14 11:27:10

标签: c++ c qt pipe

您好我在Linux上工作,我正在尝试创建一个GUI应用程序,以配合我的可执行文件。

出于某种原因,它意外地结束了。没有错误消息,它只是在Qt控制台窗口中说它意外地以退出代码0结束。

有人可以帮我看一下。我在Linux上工作。

我也会在这里粘贴代码。

void MainWindow::on_pushButton_clicked()
{
    QString stringURL = ui->lineEdit->text();

    ui->labelError->clear();
    if(stringURL.isEmpty() || stringURL.isNull()) {
        ui->labelError->setText("You have not entered a URL.");
        stringURL.clear();
        return;
    }

    std::string cppString = stringURL.toStdString();
    const char* cString = cppString.c_str();

    char* output;

    //These arrays will hold the file id of each end of two pipes
    int fidOut[2];
    int fidIn[2];

    //Create two uni-directional pipes
    int p1 = pipe(fidOut);                //populates the array fidOut with read/write fid
    int p2 = pipe(fidIn);                 //populates the array fidIn  with read/write fid
    if ((p1 == -1) || (p2 == -1)) {
        printf("Error\n");
        return;
    }

    //To make this more readable - I'm going to copy each fileid
    //into a semantically more meaningful name
    int parentRead  = fidIn[0];
    int parentWrite = fidOut[1];
    int childRead   = fidOut[0];
    int childWrite  = fidIn[1];

    //////////////////////////
    //Fork into two processes/
    //////////////////////////
    pid_t processId = fork();

    //Which process am I?
    if (processId == 0) {
        /////////////////////////////////////////////////
        //CHILD PROCESS - inherits file id's from parent/
        /////////////////////////////////////////////////
        ::close(parentRead);      //Don't need these
        ::close(parentWrite);     //

        //Map stdin and stdout to pipes
        dup2(childRead,  STDIN_FILENO);
        dup2(childWrite, STDOUT_FILENO);

        //Exec - turn child into sort (and inherit file id's)
        execlp("htmlstrip", "htmlstrip", "-n", NULL);

    } else {
        /////////////////
        //PARENT PROCESS/
        /////////////////
        ::close(childRead);       //Don't need this
        ::close(childWrite);      //

        //Write data to child process
        //char strMessage[] = cString;
        write(parentWrite, cString, strlen(cString));
        ::close(parentWrite);     //this will send an EOF and prompt sort to run

        //Read data back from child
        char charIn;
        while ( read(parentRead, &charIn, 1) > 0 ) {
            output = output + (charIn);
            printf("%s", output);
        }
        ::close(parentRead);      //This will prompt the child process to quit
    }

    return;
}

编辑::调试结果

我运行了调试器,这是我收到的错误:

The inferior stopped because it received a signal from the Operating System.

Signal name : SIGSEGV
Signal meaning : Segmentation fault

1 个答案:

答案 0 :(得分:5)

您尚未初始化“输出”变量。在代码的最后几行,您可以执行以下操作:

while ( read(parentRead, &charIn, 1) > 0 ) {
    output = output + (charIn);
    printf("%s", output);
}

由于您要将从子进程读取的字节添加到输出变量(这是一个包含垃圾的指针),然后将“output”变量的地址的内容作为字符串打印,这将会产生令人讨厌的事情。您可能希望“输出”为std::string,这样您的代码就有意义了:

std::string output;
/* ... */
while ( read(parentRead, &charIn, 1) > 0 ) {
    output += (charIn);
}
std::cout << output;

读完子进程生成的所有数据后,可以将其写入stdout。

编辑:既然你想将“输出”的内容设置为QPlainTextEdit,你可以使用QPlainTextEdit :: setPlainText:

while ( read(parentRead, &charIn, 1) > 0 ) {
    output += (charIn);
}
plainTextEdit.setPlainText(output.c_str());