Qt如果我QApplication::exec()用标准的Windows消息循环实现代替,我会错过任何功能吗?这应该澄清我的意思:
用于运行事件处理的因果"Qt"方式:
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
Window w;
w.show();
return a.exec();
}
Run Code Online (Sandbox Code Playgroud)
"Windows"方式运行事件处理:
#include <Windows.h>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
Window w;
w.show();
MSG msg;
while(GetMessage(&msg, 0, 0, 0)){
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return msg.wParam;
}
Run Code Online (Sandbox Code Playgroud)
上面演示了关于QApplication实例的外部消息循环,而QApplication实例本身甚至根本没有自己的事件循环.
换句话说,如果我有main.exe消息循环的程序(对Qt一无所知).dll和QApplication内部的Qt GUI和实例,是否可以让外部消息循环main.exe来处理Qt GUI的事件?提前致谢!
编辑1: 我只是回答我自己的情况下,它是有用的人:我们有.NET下的C#编写的一个主要的.exe模块运行事件循环处理,我们有一对夫妇写的Qt/C++具有.DLL文件的GUI"内部"(以及共享的QApplication实例).永远不会调用QApplication :: exec(),但主.exe(.NET)模块的事件循环会成功调度所有事件,并且所有Qt函数都存在(信号/插槽,线程等)
编辑2: 这适用于Qt 4.8.2,但对于Qt 5.1.0,情况有点不同.现在你必须调用QApplication :: processEvents()一次,因为它在第一次调用时执行一些初始化初始化(在GetMessage或PeekMessage上安装WindowsHook).之后,无论谁在你的应用程序中调用GetMessage,Qt事件都会获得进程并且你是金色的:)