WSARecv参数lpNumberOfBytesRecvd的一个变态问题

来源:互联网 发布:微博刷赞软件手机版 编辑:程序博客网 时间:2024/05/15 11:26

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

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