您的位置:首页 > 编程语言 > C#

C# 判断socket断开

2012-09-12 09:10 183 查看

C# 判断socket断开

标签:
socket 断开
2008-04-17 17:31

在做就餐机PCCserver时,发现个问题,当客户端已经将socket正常关掉时,服务器端的socket.connected还是显示true,并没有判断出客户端断开,而C++就能够通过检测close事件,立刻判断出客户端断开。后来查阅资料发现,服务器端需要通过发送数据才能检测出客户端中断。

以下是我参考的一点资料:

首先,Socket类的Connected属性只表示最后一次I/O操作的状态,如果这之后[连接的另一方]断开了,它还一直返回true, 除非你再通过socket来发送数据。所以通过个属性来判断是行不通的!

有人说可以用Socket.Available属性来判断,msdn中说:如果[连接的另一方]断开了,它就会抛出异常。然而,这个BUG报告(http://dam.mellis.org/2004/08/net_socket_bugs_gotchas/)却指出:msdn的说法并不完全正确,这个属性只有在少数情况下才抛出异常。所以,这一招还是行不通!

事实上,Socket.Receive()方法在[连接的另一方]断开时,它返回结果告知只读了0个字节,我们可以籍由这一点来找出答案。这个问答(http://www.dotnet247.com/247reference/msgs/36/182526.aspx)给出了好的解决方案:可以调用Socket.Poll()
方法,为该方法的第二个参数传入SelectRead 值,如果该方法返回true, 则可以再由Socket.Receive()方法的返回值来判断, 我简要的写出代码:

Socket s = new Socket(..);

if (s.Poll(-1, SelectMode.SelectRead))

{

int nRead = s.Receive();

if (nRead == 0)

{

//socket连接已断开

}

}

但是我发现参考资料上给的方法也不是很好用,因为即便是网络正常连接时,nRead的值也可能是0,比较郁闷。看来只能用频繁发送探测包的方法了。

困扰了我一天的问题,在这里做个小记。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: