ICOP知识(转)
来源:互联网 发布:帝国cms 中华养生 编辑:程序博客网 时间:2024/05/29 02:43
Tip 1 : 使用WSASend/WSARecv来收发数据,而不是使用ReadFile/WriteFile
一句话,前者具有更好的性能
Tip 2: 理解IOCP的最大并发线程数和工作线程数
应该让工作线程数(调用GetQueuedCompletionStatus那些线程)大于等于在CreateIoCompletionPort 指定的NumberOfConcurrentThreads数。
标准做法是永远设置NumberOfConcurrentThreads=0
Tip 3: 利用GetQueuedCompletionStatus的completion key和overlapped structure参数在异步操作中来传递信息
通常completion key用来传递和handle/socket/session的信息
而overlapped structure用来传递每次异步I/O的一些信息,通常的做法是会定义一个structure来派生于OVERLAPPED
struct MY_IO_DATA : public OVERLAPPED
Tip 4: 理解IOCP的完成包的排队行为
从GetQueuedCompletionStatus得到完成包的次序可能跟调用WSASend/WSARecv的次序不一样。
微软唯一保证是如果调用WSASend/WSARecv得到SUCCESS或者IO_PENDING,就一定会有一个完成包出现在IOCP的队列上,不管这个socket是否关闭了。
如果关闭socket,那么之后的WSASend/WSARecv调用就一定返回失败的结果。
关于IOCP包可能次序错乱和解决方法,有一篇文章可以参考: http://www.codeproject.com/KB/IP/reusablesocketserver4.aspx
我的做法是避免多次调用WSARecv
Tip 5: IOCP的清除
最重要的一点是,在I/O完成之前,不要释放overlapped structure。可以用HasOverlappedIoCompleted来监测OV是否完成。
通常的做法是
1) 调用PostQueueCompletionStatus N次(N=工作线程数),来传递特殊的退出信息给所有的工作线程
2) 关闭所有的socket,如果很在意处理完未完成的数据包,需要使用一个计数器来跟踪异步I/O事件,直到计数器为0,才关闭相应的socket
3) 关闭completion port
- ICOP知识(转)
- ICOP
- ICOP
- ICOP Win异步通讯
- icop vortex-86 新更新的bsp似乎有问题
- 经证实Icop-Vortex86DX_60B_BSP_091028 这一bsp不支持vdx6354
- ICOP的一些结论 -- 仅是我的实践结论
- Java注解开发及ICOP平台中的应用
- XSLT知识总结(转)
- USB小知识(转)
- C++面试知识 (转)
- XenStore相关知识(转)
- VC小知识(转)
- XenStore相关知识(转)
- memcached相关知识(转)
- (转)编码相关知识
- (转)android 小知识
- 博弈知识汇总(转)
- Javascript中最常用的55个经典技巧
- XMLHTTP(readyState,status)对应的状态值
- C#与Java的一些区别
- 最简单的mysql的中文编码问题
- JavaScript读取URL参数
- ICOP知识(转)
- 第一次登上csdn,想说几句
- 常用pop3和smtp列表
- WTL资料
- 本地计算机上的OracleOraHome92Agent服务启动后又停止了
- 在DataGridView指定行添加ComboBox
- monorail----ViewComponents
- 弦图判断
- SQL Server学习笔记之 T-SQL研究之[基本查询]