我有以下线程池。
#include <queue>
#include <map>
#include <boost/shared_ptr.hpp>
#include <boost/asio/io_service.hpp>
#include <boost/thread/thread.hpp>
#include <boost/asio.hpp>
#include <boost/date_time/posix_time/posix_time.hpp> // remove me (only for io)
class ThreadPool
{
void run() {
// get some work from a task queue and then work on it
}
public:
void work_as_mainthread(void) { m_io_service.run(); }
ThreadPool(int poolSize = 4) : timer(m_io_service)
{
timer.expires_from_now(boost::posix_time::seconds(1));
m_pWork.reset( new boost::asio::io_service::work(m_io_service) );
for ( int i = 0; i < poolSize; ++i)
m_threadGroup.create_thread( boost::bind(&boost::asio::io_service::run, &m_io_service) );
}
private:
boost::asio::io_service m_io_service;
boost::asio::deadline_timer timer;
boost::shared_ptr<boost::asio::io_service::work> m_pWork;
boost::thread_group m_threadGroup;
};
int main()
{
int n_threads = 2;
ThreadPool pool(n_threads);
// add some tasks here...
pool.work_as_mainthread();
return 0;
}
这是一个最小的问题,完整的代码here。编译如下:
g++ -Wall -g -lboost_thread -lboost_date_time -lboost_system main.cpp -o main
请注意,我没有调用async_wait()(我不知道为什么我需要它,到目前为止线程池工作)。
现在,可能会发生突然一个任务要求在另一个任务超时之前完成另一个任务。告诉m_io_service立即执行处理程序的最佳方法是什么(即使计时器还不感兴趣),然后继续,好像什么也没发生?我真的无法从稀疏的文档中找到答案。
这不起作用:
timer.expires_at(boost::posix_time::microsec_clock::universal_time());
答案 0 :(得分:2)
请注意,expires_at
仅设置dealine_timer
到期时间,但不会“启用”计时器,因此没有与计时器关联的异步操作。你应该调用async_wait
传递一个完成处理程序:当超时到期或取消定时器时,在一个相关的io_service
的线程中调用这个处理程序。
致电io_service::post
与deadline_timer
无关。它只是将您的仿函数发布到io_service
队列,而io_service
会尽快在其中一个线程中调用它。