读书人

疑窦求解:asio io_service:run sle

发布时间: 2012-10-15 09:45:25 作者: rapoo

疑难求解:asio io_service::run sleep(0)
环境如下:

小弟我使用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)不管用呢?



[解决办法]
sleep(0)只是放弃了当前的时间片,并不表示下一个时间片一定是别人的。

读书人网 >C++

热点推荐