首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ >

疑窦求解:asio io_service:run sleep(0)

2012-10-15 
疑难求解:asioio_service::runsleep(0)环境如下:小弟我使用asio,编写tcp服务端程序。windows XP测试环境,成

疑难求解: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)只是放弃了当前的时间片,并不表示下一个时间片一定是别人的。

热点排行