疑难求解:asio io_service::run sleep(0)
audi2 2012-09-24 02:17:50 环境如下:
小弟我使用asio,编写tcp服务端程序。
windows XP测试环境,成功接入9000个连接。
只开一个io_service::run()线程,便于调试。
有一堆的业务处理线程。所有的线程都是默认的优先级。
采用boost内存池,handler_allocator,asio::buff等技术,大大的减少了动态内存分配开销
问题描述:
io_service::run()线程是CPU密集型的,不读写数据库,偶尔打印一下日志(用log4cxx库)。
当逐渐加大连接数时,突然发现一个“业务处理线程”不跑了(应该还活着)。
考虑可能是io_service::run()线程太忙了,我加入了Sleep(0)主动放弃CPU,问题仍存在。
然后我把Sleep(0)改成Sleep(1)后,问题解决了。
为什么Sleep(0)不管用呢?