2012-03-14 3 views
1

Привет, Я работаю над Linux, и я пытаюсь создать графическое приложение, чтобы выполнить мой исполняемый файл, который я сделал.Приложение Qt 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; 
} 

EDIT :: DEBUGGING РЕЗУЛЬТАТЫ

Я побежал отладчик и это ошибка, я получил:

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

Signal name : SIGSEGV 
Signal meaning : Segmentation fault 
+0

вы пробовали запустить его в отладчике? Это может помочь вам выяснить, что не так, а главное - где-то не так. –

+0

В дополнение к простому обнаружению причины (сигнала) вы должны иметь возможность выполнить отрыв отладчика в этой точке и увидеть линию нарушения. Основные навыки отладки. – Macke

+0

То, что вы хотите вставить в таких ситуациях, это вывод «bt» (backtrace) –

ответ

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; 

После того, как вы прочитали все данные ваш дочерний процесс сгенерированные, вы можете записать его на стандартный вывод.

EDIT: так как вы хотите, чтобы установить содержание «выход» на QPlainTextEdit, вы можете использовать QPlainTextEdit :: setPlainText:

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

Привет, спасибо за ответ. Я не получаю ошибку сейчас. Но знаете ли вы, как я получаю вывод для печати в plainTextEdit? – user667430

+1

Я отредактировал свой ответ, проверьте его сейчас. – mfontanini

+0

Спасибо, что работал – user667430

Смежные вопросы