zoukankan      html  css  js  c++  java
  • IOCP编程注意事项

    1、每个连接同时最好只有一个待决的WSARecv。IOCP不保证多个待决WSARecv情况下先投递的WSARecv就一定会先得到完成通知。因此

    ,多个待决WSARecv可能导致数据乱序,无谓增加代码复杂性。
     
          2、投递0长度缓冲区的WSARecv可以不占用非分页内存,避免WSAENOBUFS错误。
     
          3、每个连接同时最好只有一个待决的WSASend。发送数据会锁定系统费非分页内存,过多的WSASend会导致WSAENOBUFS错误,麻烦的事

    情。
     
          4、WSASend直接返回成功,说明数据已复制到发送缓冲区;若WSA_IO_PENDING,则当得到完成通知时,不会出现只发送部分数据的情

    况(本人未具体研究,只是别人看了泄露的NT4.0的代码的得到的结论,为了万全,还是要考虑发送部分数据的情况,若出现发送部分数据情

    况,那么一个连接投递多个WSASend就不行了,投递WSASend相当于追加发送缓冲区,滑动窗口未必会一次性更新)。
     
          5、IOCP是为响应大规模并发连接,做到了1、2、3和4能够尽可能的增加连接并发数量:因为并发数量很大程度是由非分页内存的占用

    量决定的。
     
          6、服务端应该提供强制关闭和优雅关闭连接功能。推荐使用强制关闭,以避免socket的TIME_WAIT状态。 
     
          7、多多利用DisconnectEx函数实现socket 重用,因为socket的分配是有代价的。
     
          8、当socket资源被释放后,若不存在TIME_WAIT状态,要警惕系统立即把该socket值分配给新的连接,这就导致资源释放与新旧

    socket资源同步问题。建议socket出错后,先释放相关资源,再closesocket或者DisconnectEx。
     
          9、DisconnectEx不能实现强制关闭:即使设置SO_LINGER选项,DisconnectEx也不会发出RST,只有FIN。
     
          10、当新建一个连接后,要对新的socket设置SO_UPDATE_ACCEPT_CONTEXT选项,否则对其的shutdown和DisconnectEx会有WSAENOTCONN错误,算是个bug。
     
          11、这个和强制关闭有关:取消已经投递的IO操作,可以使用的函数有CancelIO和CancelIOEx,具体区别参见MSDN。要注意,CancelIOEx需要Windows Server 2008及以上、Windows Vista及以上。


          12、考虑提供接收和发送紧急数据的接口。


          13、Overlapped(重叠)方式类似于zero-copy:直接锁定用户buffer至非分页内存。

          14、调用DisconnectEx()成功后,socket仍然和先前的绑定的完成建一一对应,除非使用closesocket()。

           15、当然直接closesocket()也可以取消已投递的IO操作,但是要注意到资源同步的问题、可能发生的socket资源再分配问题。

           16、GetQueuedCompletionStatusEx()是个好函数:一次调用尽可能多的获得完成通知,减少用户态和内核态之间的切换。

  • 相关阅读:
    C++中如何使用大整数__int 128
    全排列问题
    读书札记:瑞士法郎的因素
    读书札记:影响欧元的因素
    金融市场:最全的外汇平台资料大全(包括开户金额、点差、特色!)
    读书札记:澳大利亚元因素
    情感日记:祭衣文
    情感日记:第一次亲密的接触
    读书札记:美元影响的因素
    读书札记:外汇市场
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13318556.html
Copyright © 2011-2022 走看看