socket_recv函数使用心得
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
recv的超时总结
说明:针对recv返回值,阻塞情况下,当网络异常时,recv是返回个-1,还是阻塞不动,还是根据情况而定呢
一
1.不论是阻塞还是非阻塞,都是<0:出错,=0:连接关闭,>0接收到数据大小
2.Recv<0情况
1、特别:返回值<0时并且(errno == EINTR || errno == EWOULDBLOCK || errno == EAGAIN)的情况下认为连接是正常的,继续接收。
2、只是阻塞模式下recv会阻塞着接收数据,非阻塞模式下如果没有数据会返回,不会阻塞着读,因此需要循环读取)。阻塞情况下,阻塞接收,不会返回负数吗?
3、很多人说阻塞模式下read会阻塞着读,是否这样?我和同事试了不会阻塞,而是会返回一个负数。对吗?
4、阻塞模式下read返回值< 0 && errno != EINTR && errno != EWOULDBLOCK && errno != EAGAIN时,连接异常,需要关闭,read返回值< 0 && (errno == EINTR || errno == EWOULDBLOCK || errno == EAGAIN)时表示没有数据,需要继续接收,如果返回值大于0表示接送到数据。
二
getsockopt与setsockopt
1.getsockopt可以获取套接字的属性,Setsockopt可以设置套接字的属性。
Int getsockopt(int s, int level, int optname, void *optval, socketlen_t *optlen) int setsockopt(int s, int level, int optname, const void *optval, socketlen_t optlen)。两个函数成功返回0,失败返回-1,错误代码存于errno中。
2.S:套接字
Level:套接字选项操作的层次。可以取:SOL_SOCKET(通用套接字);
IPPROTO_IP(IP 层套接字);IPPROTO_TCP(TCP 层套接字)。
Optname:套接字选项名称
Optval:套接字选项的值
Optlen:选项值的大小
3.通用套接字的选项
a)SO_KEEPPALIVE:如果一段时间内没有反应,则关闭socket。若没
有设置此选项,则socket一直被阻塞。
b)SO_RCVLOWAT:接收缓冲区的下限,只有缓冲区数据超过了
SO_RCVLOWAT才会将数据传到上层应用层。
SO_SNDLOWAT:发送缓冲区的下限,……..才会将数据发送。
c)SO_RCVTIMEO:设置套接字的超时时间,见结构体struct timeval.
d)SO_BINDTODEVICE:将套接字绑定到特定的网络接口,如eth0。
e)SO_DEBUG:只能对TCP套接字使用,设置该选项后系统将保存TCP
发送和接收的所有数据相关信息。
f)SO_REUSEADDR:绑定套接字用到。套接字正常关闭或异常退出后
的一段时间内,端口依然维持原来的绑定状态,设置此选项后避免。
g)SO_TYPE:获取套接字的类型。SOCK_DGRAM、SOCK_STREAM…
h)SO_ACCEPTCONN:检测套接字是否处于监听状态,0表示非监听
状态。1表示在监听。
i)SO_BROADCAST:决定套接字是否能够广播。类似于REUSEADDR
的用法。
j)SO_SNDBUF、SO_RCVBUF:用于设置套接字的发送和接收缓冲区的大小。默认值是多少?
k)SO_ERROR:套接字上发生了异步错误,系统将设置套接字的SO_ERROR,getsockopt调用后so_error的值将自动初始化。
三
多路复用select( )
四测试实验(linux下测试)
1、Client端与server端保持通信,3512板断电,client端recv堵住不动。
2、断网,recv亦堵住不动。
3、断网,send端发送数据也会堵住不动,为什么这与项目中的情况不一样?Winsocket么?
4、winsock send会堵住20秒或1分钟,随后便返回-1,这与理论上是不一样的(正常情况下,如果没有设置超时的话,send和client都会堵住不动)
5、winsock recv正常,也会堵住
6、recv采取阻塞方式也不一定收len长度,应用while循环。