WSARecv参数lpNumberOfBytesRecvd的一个变态问题

这个函数干嘛的我就不多说了,搞winsock编程的都认识它!
我在使用这个函数时,按照MSDN上的描述,将lpNumberOfBytesRecvd设定成了NULL,因为咱是IOCP嘛,照MSDN的说法,如果LPWSAOVERLAPPED不为NULL,那么这个参数可以设定为NULL。
我也就这样使用了,程序跑起来,测试也正常,但是有些情况下不稳定,我这可是服务器啊,任何问题都必须被消灭,于是开始Debug服务器,经过一天的折腾之后我发现在WSARecv之后有时会有一个异常输出,意思就是访问了非法内存,但是被C++库截获并解决掉了,奇怪怎么会有这个问题?

再反复琢磨了WSARecv的参数之后,我决定给lpNumberOfBytesRecvd设置一个有效的地址试试,当然这样考虑的原因就是BT的问题一定要BT的解决。结果一运行再也不输出任何关于访问非法内存的异常,再仔细跟踪发现lpNumberOfBytesRecvd这个参数有些情况下会同步的返回接收的字节数,虽然在IOCP模型中这可能已经没有意义了,因此我猜测在WSARecv函数的实现中,总是会写这个值在lpNumberOfBytesRecvd中,而不管这个地址是否有效,由此推测微软的程序员也是会偷懒的,不检查参数,而是像java程序员一样依赖异常处理来搞定问题。但是对于服务器来说异常过多就意味着效率的极端低下,以及潜在的不稳定。因此要想办法消灭每一个异常。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值