最近做的一个项目需要将程序大量图片画面显示在扩展屏上,通过在同一进程加入窗口然后显示发现如果画面显示频繁会导致界面有些卡顿,所以想到了通过进程间通信的方式将显示图片以共享内存的方式传给其它进程显示。
于是用了QPrcoss来启动和关闭外部进程,然后遇到了一个问题,调用QProcess::close方法关闭外部进程时不会进入外部进程窗口的析构函数,从而导致外部进程的一些资源无法释放产生异常。后尝试用kill,terminate,均无果,后有点郁闷,秉着不信邪的信念(= =)最终还是找到了解决方法:
在共享内存的内存中增加标志位,然后在外部进程中持续监控标志位,要关闭外部进程时提前写入标志位然后等待100ms(给外部进程释放资源的时间),这样测试问题解决。
上代码:
启动外部进程:
QProcess* pro = new QProcess;
pro->start("MissleExtendsVideo.exe", strList);
关闭外部进程:
shareVideo1.PushCloseData(); //共享内存关闭标志位
Sleep(100);
PushCloseData()代码:
sharememory.lock();
char* sm = static_cast<char*>(sharememory.data());
sm[0] = 2; //在这里设定标志位
sharememory.unlock();
外部进程代码就不贴了,说下思路,启动个线程,在里面持续监测共享内存位置即可。
虽然问题解决了,但是对于QProcess::close()的方法不触发析构还是耿耿于怀,大家有通过QProcess方式解决的可以分享下哈