qt多线程间通信
来源:互联网 发布:linux 查看启动时间 编辑:程序博客网 时间:2024/06/16 10:54
//Qt多线程同步
QMutex g_mutex;
QWaitCondition g_waitobj;
//回调函数
int __cdecl CMediaServerCallBack::requestAuthorizeCallback(const char* a_device_uuid
, AuthorizedCode* a_auth_code, void* a_context)
{
//由于需要界面来作相应操作(主线程),所以只能用信号槽来处理
emit MS_CALLBACK->signalRequestAuthor(a_device_uuid, a_auth_code);
//由于需要等待界面的处理结果,所以需要阻塞该线程
//之前直接用while来做死循环
QMutexLocker mutexLocker(&g_mutex);
g_waitobj.wait(&g_mutex);
return 0;
}
, AuthorizedCode* a_auth_code)
{
//修改 a_auth_code, 修改完成后,唤醒之前阻塞的线程
QMutexLocker mutexLocker(&g_mutex);
g_waitobj.wakeOne();
}
QMutex g_mutex;
QWaitCondition g_waitobj;
//回调函数
int __cdecl CMediaServerCallBack::requestAuthorizeCallback(const char* a_device_uuid
, AuthorizedCode* a_auth_code, void* a_context)
{
//由于需要界面来作相应操作(主线程),所以只能用信号槽来处理
emit MS_CALLBACK->signalRequestAuthor(a_device_uuid, a_auth_code);
//由于需要等待界面的处理结果,所以需要阻塞该线程
//之前直接用while来做死循环
QMutexLocker mutexLocker(&g_mutex);
g_waitobj.wait(&g_mutex);
return 0;
}
//槽函数,响应回调函数中的 MS_CALLBACK->signalRequestAuthor(a_device_uuid, a_auth_code)
void CGUIMediaCenter::onRequestAuthor(const char* a_device_uuid, AuthorizedCode* a_auth_code)
{
//修改 a_auth_code, 修改完成后,唤醒之前阻塞的线程
QMutexLocker mutexLocker(&g_mutex);
g_waitobj.wakeOne();
}
0 0
- qt多线程间通信
- QT多线程通信EMIT
- Qt TCP通信,多线程服务器端
- QT:多线程及通过事件进行通信
- QT中的多线程-与主线程通信
- QT C++实现多线程通信--示例代码
- Qt 多线程之间的通信 实例 emit
- qt 进程间通信
- QT---线程间通信
- QT进程间通信
- QT 窗体间通信
- QT进程间通信
- QT 窗体间通信
- QT 窗体间通信
- QT---线程间通信
- Qt 窗口间通信
- QT-进程间通信
- Qt进程间通信
- Mysql 访问服务器数据库 没有权限 access denied for user
- NFS(网络文件系统) Linux 系统上常用的文件共享方式
- Android应用进程间通信之Messenger信使使用及源码浅析
- Android 获取当前APP和系统的版本信息
- Android SDK 支持的加密算法
- qt多线程间通信
- sql server 2000/2005 判断存储过程、触发器、视图是否存在并删除
- 清理和删除svn信息
- 文章标题
- getgid getuid
- 当出现『SIOCADDRT: Network is unreachable』 这个错误时,肯定是由于 gw 后面接的 IP 无法直接与您的网域沟通 (Gateway 并不在你的网域内), 所以,赶紧检
- ajax详细解读
- 出错file is universal (3 slices) but does not contain a(n) armv7s slice
- UIScrollView及UIPageControl的使用