首页 > 代码库 > iocp中GetQueuedCompletionStatus 121 信号灯超时时间已到 (error sem timeout)
iocp中GetQueuedCompletionStatus 121 信号灯超时时间已到 (error sem timeout)
报错 :121 信号灯超时时间已到 (error sem timeout)
现象和 http://bbs.csdn.net/topics/370175898 描述一致
现象:GetQueuedCompletionStatus 返回后,GetLastError = 121 (信号灯超时时间已到),出现这个提示后,服务程序变卡,客户端不能流畅的接收数据;没有这个错误则客户端接收流畅。
代码如下
void App::AnalysisCommand(const boost::system::error_code& error,size_t bytes_recvd){ if(!error && bytes_recvd > 0) {
........
boost::asio::async_read(socket_, boost::asio::buffer(m_buff, sizeof(MessageHeader)), boost::bind(&App::AnalysisCommand, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred)); } else { LOG_ERROR<<"socket receive error message:"<< error.value()<<error.message();
}}
http://bbs.csdn.net/topics/370175898
https://blogs.msdn.microsoft.com/oldnewthing/20140717-00/?p=483/
http://microsoft.public.win32.programmer.networks.narkive.com/YVjj9q6G/calls-to-getqueuedcompletionstatus-returns-error-netname-deleted-or-error-sem-timeout#post1
http://blog.csdn.net/brook0344/article/details/60479590
根据csdn上那哥们说的,ERROR_SEM_TIMEOUT 每秒收到5000个以上的Accept时出现
iocp中GetQueuedCompletionStatus 121 信号灯超时时间已到 (error sem timeout)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。