如何判断socket是否断开
2017-10-26
展开全部
1. 根据ERRNO和recv结果进行判断
在UNIX/LINUX下,非阻塞模式SOCKET可以采用recv+MSG_PEEK的方式进行判断,其中MSG_PEEK保证了仅仅进行状态判断,而不影响数据接收
对于主动关闭的SOCKET, recv返回-1,而且errno被置为9(#define EBADF 9 /* Bad file number */)或104 (#define ECONNRESET 104 /* Connection reset by peer */)
对于被动关闭的SOCKET,recv返回0,而且errno被置为11(#define EWOULDBLOCK EAGAIN /* Operation would block */)
对正常的SOCKET, 如果有接收数据,则返回>0, 否则返回-1,而且errno被置为11(#define EWOULDBLOCK EAGAIN /* Operation would block */)
因此对于简单的状态判断(不过多考虑异常情况):
recv返回>0, 正常
返回-1,而且errno被置为11 正常
其它情况 关闭
[c] view plain copy
int np_socket_alive (int conn_fd) {
char buff[32];
int recv_buff = recv (conn_fd, buff, sizeof (buff), MSG_PEEK);
int sockErr = errno;
if (recv_buff > 0) // Get Data
return 1;
if ((recv_buff == -1) && (sockErr == EWOULDBLOCK)) // No Data recieved
return 1;
return -1;
}
2. 通过TCP_KEEPALIVE进行判断
在UNIX/LINUX下,非阻塞模式SOCKET可以采用recv+MSG_PEEK的方式进行判断,其中MSG_PEEK保证了仅仅进行状态判断,而不影响数据接收
对于主动关闭的SOCKET, recv返回-1,而且errno被置为9(#define EBADF 9 /* Bad file number */)或104 (#define ECONNRESET 104 /* Connection reset by peer */)
对于被动关闭的SOCKET,recv返回0,而且errno被置为11(#define EWOULDBLOCK EAGAIN /* Operation would block */)
对正常的SOCKET, 如果有接收数据,则返回>0, 否则返回-1,而且errno被置为11(#define EWOULDBLOCK EAGAIN /* Operation would block */)
因此对于简单的状态判断(不过多考虑异常情况):
recv返回>0, 正常
返回-1,而且errno被置为11 正常
其它情况 关闭
[c] view plain copy
int np_socket_alive (int conn_fd) {
char buff[32];
int recv_buff = recv (conn_fd, buff, sizeof (buff), MSG_PEEK);
int sockErr = errno;
if (recv_buff > 0) // Get Data
return 1;
if ((recv_buff == -1) && (sockErr == EWOULDBLOCK)) // No Data recieved
return 1;
return -1;
}
2. 通过TCP_KEEPALIVE进行判断
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询