//设置发送超时
你只发送, 并发送足够多的数据以填满发送缓冲区, 接收端一直不接收.
发送端一量满发送缓冲区就会阻塞, 若是你设置了发送超时, 超时到了它就会返回发送超时了.网络
在进行程序开发时,有时候须要阻塞,但同时又须要有超时功能,这时候select()函数就能很好的知足咱们的要求:并发
但用这进行测试时有一个地方是须要注意的,即select()的第五个参数timeval *timeout的问题。设置好timeout的始值后,若是只对select()调用一次,是没有任何问题的,但一旦屡次调用,你就会发现怎么好像我设置的timeout值只有第一次有用呢,之后select()老是一刻也不等就返回了呢?socket
经过查看man和本身测试,原来select()函数内部是会不断更新timeout的值的,以查看超时时间还剩多少。那么第一次调用以后,timeout的值就被更新至0了,之后无论你再调用它多少次,select()都会当即返回了,这就是为何会出如今屡次调用时,select()只有第一次时凑效的原因了,哈哈,之后再使用它时,要尤为注意这一点了。但它的兄弟函数pselect()没有它的这个问题,它不会在内部在时间值进行更新的。函数
socket在每次执行select的时候都得要从新对time进行赋值 防止select修改了time参数 对下一次的判断形成干扰 for (i = 0 ; i < waittimeout ; i++) { FD_SET(fd , &fdr); sTime.tv_sec = 1; sTime.tv_usec = 0; iRet = select(iMax , &fdr , NULL , NULL , &sTime); if (iRet == -1) { LOG_TRACE(&gLogger, "select -1"); return -1; } else if (iRet > 0) { LOG_TRACE(&gLogger, "wait %ds sock readalbe, select=%d", i, iRet); return 0 ; } }