总结一个主进程启动子进程,删除主进程文件和目录的问题

首先,我们启动子进程的时候,要修改子进程的工作目录。

      ProcessStartInfo pi = new ProcessStartInfo(fileName, arguments)
      {
        WorkingDirectory = Path.GetTempPath()
      };
      pp.StartInfo = pi;
      pp.Start();

这里我把工作目录随便指定了一个地方,目的是防止子进程默认继承了主进程的工作目录。如果你省了这一个地方,只要子进程开着,那它的工作目录就和主进程的工作目录是一样的,结局就是子进程删除主进程的工作目录,其实是被子进程自己占用着的,就算主线程关闭了也是如此。

比如,你想做最简单的installer.exe更新,可能就是主线程下载,主线程启动installer.exe执行静默安装(更新),然后发现bong,出问题了。

转载于:https://www.cnblogs.com/3Tai/p/7213863.html

当涉及到主进程子进程之间的通信时,可以使用Qt的信号槽机制来实现。以下是一个简单的示例,展示了主进程子进程之间的信号槽通信。 主进程代码: ```cpp #include <QCoreApplication> #include <QProcess> #include <QDebug> int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); QProcess childProcess; childProcess.start("./child_process"); // 启动子进程 // 连接子进程的信号和主进程的槽 QObject::connect(&childProcess, &QProcess::readyReadStandardOutput, [&childProcess]() { qDebug() << "Received data from child process:" << childProcess.readAllStandardOutput(); }); // 向子进程发送数据 childProcess.write("Hello from parent process!"); return a.exec(); } ``` 子进程代码(保存为child_process.cpp): ```cpp #include <QCoreApplication> #include <QDebug> int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); qDebug() << "Child process started."; // 发送数据给主进程 qDebug() << "Sending data to parent process."; qDebug().noquote() << "Hello from child process!"; return a.exec(); } ``` 在这个例子中,主进程创建了一个子进程,并与子进程的readyReadStandardOutput信号连接起来。当子进程有输出时,主进程的槽函数会被调用,并打印接收到的数据。 子进程启动后,会发送一条数据给主进程。在这个例子中,子进程通过qDebug输出数据,而主进程通过childProcess.readAllStandardOutput()接收数据。 请注意,这只是一个简单的示例,实际的应用中可能需要更复杂的通信逻辑和同步机制来确保正确的数据传输和处理。 希望这个例子能对你有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值