似乎为 Signal 类和插槽中调用的内容提供安全跨线程信号的唯一实现是 QT。(也许我错了?)。
但是我不能在我正在做的项目中使用 QT。那么我怎样才能从不同的线程提供安全的 Slots 调用(例如使用 Boost::signals2)?插槽内的互斥锁是唯一的方法吗?我认为信号2可以保护自己,但不能保护插槽内正在执行的操作。
谢谢
似乎为 Signal 类和插槽中调用的内容提供安全跨线程信号的唯一实现是 QT。(也许我错了?)。
但是我不能在我正在做的项目中使用 QT。那么我怎样才能从不同的线程提供安全的 Slots 调用(例如使用 Boost::signals2)?插槽内的互斥锁是唯一的方法吗?我认为信号2可以保护自己,但不能保护插槽内正在执行的操作。
谢谢
您可以结合 boost::bind 和 boost ASIO 来创建跨线程调用。
# In Thread 2
boost::asio::io_service service;
boost::asio::io_service::work work (service); // so io service won't stop if there is no work
service.run() # starting work thread
# In Thread 1
service.post (boost::bind (&YourClass::function, &yourClassInstance, parameter1, parameter2))
线程 2 将进入一个循环并执行您的绑定函数。我认为您也可以将 Boost::Signals2 调用调用到此循环中。
但请注意:如果您执行跨线程信令,请确保目标对象在被调用时仍然存在。您可以通过删除目标析构函数中的所有连接来保证这一点(不是在它们的基类析构函数中,另请参见Signals-Trackable Class)
我不太喜欢 Boost::Signals2,因为它的堆栈跟踪和编译时间很长(博客文章)。
确切地说,它不是信号槽实现,而是 Twisted 的延迟模式的 C++ 实现,它实现了与跨线程信号槽机制类似的目标。如果有人没有出现并发布更好的解决方案,可能值得一看:http: //sourceforge.net/projects/deferred/