标签:sizeof blog ima 问题 缓冲 目的 socket size null
//设置发送超时
你只发送, 并发送足够多的数据以填满发送缓冲区, 接收端一直不接收.
发送端一量满发送缓冲区就会阻塞, 如果你设置了发送超时, 超时到了它就会返回发送超时了.
在进行程序开发时,有时候需要阻塞,但同时又需要有超时功能,这时候select()函数就能很好的满足我们的要求:
但用这进行测试时有一个地方是需要注意的,即select()的第五个参数timeval *timeout的问题。设置好timeout的始值后,如果只对select()调用一次,是没有任何问题的,但一旦多次调用,你就会发现怎么好像我设置的timeout值只有第一次有用呢,以后select()总是一刻也不等就返回了呢?
通过查看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 ; } }
标签:sizeof blog ima 问题 缓冲 目的 socket size null
原文地址:http://www.cnblogs.com/zhangmo/p/7487542.html