微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

QtConcurrent::run 在几个小时后停止工作

如何解决QtConcurrent::run 在几个小时后停止工作

我在使用 QtConcurrent::run (Qt 5.8.9) 时遇到了一个奇怪的问题。我在一个长时间运行的应用程序(一个小型​​ Web 服务器应用程序)中使用它。 QtConcurrent::run 用于应用程序的多个位置,并且通常工作正常。

最近在某台机器(Windows 10 x64、虚拟机、4 个虚拟至强处理器、1 个核心)上,我一直遇到 QtConcurrent::run 在应用程序执行几个小时后停止工作,这是获得它再次工作是重新启动应用程序。

调试证明QtConcurrent::run被正确执行了,但是要执行的runnable/functor从来没有被调用过。

QtConcurrent::run 使用全局 QThreadPool。在启动应用程序和一些 QtConcurrent::run 调用之后,在调试器中可以看到合理数量的 QThreadPool 线程正在等待如下工作:

[Inline Frame] Qt5Core.dll!QWaitConditionPrivate::wait(QWaitConditionEvent *) Line 118  C++
Qt5Core.dll!QWaitCondition::wait(qmutex * mutex,unsigned long time) Line 179   C++
Qt5Core.dll!QThreadPoolThread::run() Line 145   C++
Qt5Core.dll!QThreadPrivate::start(void * arg) Line 380  C++

虽然我想知道为什么它们会像 Qt 文档那样保持活动状态(QThreadPool::expiryTimeout 认为 30 秒)并且我不经常使用 QtConcurrent::run,但这对我来说似乎没问题。

但在某些时候,QThreadPool 线程似乎实际上已过期(在调试器中不再可见),而且 - 更糟糕的是 - 当我再次调用 QtConcurrent::run 时,似乎没有重新启动。

有人也遇到过这个问题吗?

提前致谢

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。