QProcess and shell : Destroyed while process is still running

19,917

Solution 1

process.waitForFinished(); is hitting the default 30 seconds timeout. Use process.waitForFinished(-1); instead. This will make sure you wait for however long it takes for the process to finish, without any timeout.

Solution 2

Note you create QProcess into the local scope. This means that the object will be deleted when you exit the scope. In the destructor QProcess process terminates. The message "Destroyed" while "the process is still running" when the process terminates in the destructor.

For solving this problem, you should call QProcess destructor when process is already terminated.

If will be QProcess::waitForFinished(-1) into your example, it will occur, but this will block you application.

Share:
19,917
user2007861
Author by

user2007861

Updated on June 15, 2022

Comments

  • user2007861
    user2007861 almost 2 years

    I want to launch a shell script with Qt.

    QProcess process;
    process.start(commandLine, QStringList() << confFile);
    process.waitForFinished();
    
    if(process.exitCode()!=0)
    {
        qDebug () << " Error " << process.exitCode() << process.readAllStrandardError();
    }
    else
    {
        qDebug () << " Ok " << process.readAllStrandardOutput() << process.readAllStrandardError();
    }
    

    The result is :

    Ok : Result.... " "" QProcess : Destroyed while process is still running.

    This message does not appear every time.

    What is the problem?