加速异步计时器仍然阻塞主线程
Boost asynchronous timer still blocks the main thread
我正在尝试使用提升计时器异步执行一些操作:
boost::asio::io_service io;
boost::asio::deadline_timer t(io, boost::posix_time::seconds(5));
t.async_wait(timer_func);
io.run();
问题是 io.run() 是一个阻塞调用。我想要一个不阻塞主线程的异步计时器,然后在主线程上调用回调。这可以通过提升吗?
io_service::poll
不会阻塞。不过,您必须围绕它实现一些循环逻辑。
相关文章:
- 如何在C++上启动异步线程
- 使用 std::chrono::steady_clock 对线程/异步中的代码进行基准测试
- 调用boost.asio的异步函数时,线程是什么时候创建的
- 多个网络连接的线程与异步 I/O
- STD ::与指定线程的异步类似物
- 异步处理设备的高级线程用法
- 有没有办法为任何函数编写通用代码,以便它可以(异步)执行并从线程池中获得返回值?
- 异步记录器线程安全
- 异步是否总是在C++中使用另一个线程/内核/进程
- XAudio2 教程 - 单独的线程和异步读取?
- 使用多线程处理的异步请求
- C++ cv::Mat 返回向量的<rectangle>线程异步
- STD :: async的最大线程数量是多少,将异步创建和执行
- 发生哪些线程异步操作
- 如何实现多线程异步操作
- C++低延迟线程异步缓冲流(用于日志记录)–Boost
- QML是否与多线程/异步调用兼容
- c++的非线程异步IO简介
- 线程异步中断
- boost::asio多线程异步接受,带有阻塞读/写服务器