IOCP 生存期管理


从2004年使用iocp开始,尝试过很多种client生存期管理,最初使用
一个锁userlock,在sendcomp和recvcomp以及senddata等都用一个锁,而且是
进去的地方就开始锁,这种方式最简单,也产生了最初的版本,之后为
追求更高效率,慢慢演变为使用两个锁,readlock和writelock,再之后
演变为send使用一个锁,recv使用interlockedxxx,再之后演变为
send使用一个cs锁和一个sending,recv使用一个ref,经历了如此多种演变。

1、一个锁userlock, sendcomp recvcomp senddata都用这个锁。
2、两个锁,userlock, sendlock
3、一个锁userlock+socket查找,锁范围比1小,多一次全局查找操作。
4、一个锁sendlock,一个ref(InterlockedXXX)
   wsasend wsarecv 对象生存期等都用ref计数
5、一个锁sendlock和一个sending(InterlockedXXX),一个ref(InterlockedXXX)
   wsasend用sending计数,wsarecv等用ref计数

历经如此几个版本的修改,锁的范围越来越小,interlocked次数越来越少,反应自然
越来越快。
今天为了写总结文章,拿1 4 5进行了一次比较,1除了大量连接的时候比4 5 反应
慢了很多之外在cpu mem等占用方面几乎和4 5 相当,也就是说除了实时性方面差一些
其他方面没有太大差别。
但4 5都是用到了线程级别的内存池,1的测试例程还是用老的内存池,这个差别也
很大,所以综合地看,虽然做了很多优化却是花费80%的时间,做了20%的鸟事。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值