setsockopt && getsockopt

setsockopt(设置socket状态)        
相关函数
getsockopt
       
表头文件
#include<sys/types.h>;
#include<sys/socket.h>;
       
定义函数
int setsockopt(int s,int level,int optname,const void * optval,,socklen_toptlen);
       
函数说明
setsockopt()用来设置参数s所指定的socket状态。参数level代表欲设置的网络层,一般设成SOL_SOCKET以存取socket层。参数optname代表欲设置的选项,有下列几种数值:
SO_DEBUG 打开或关闭排错模式
SO_REUSEADDR 允许在bind()过程中本地地址可重复使用
SO_TYPE 返回socket形态。
SO_ERROR 返回socket已发生的错误原因
SO_DONTROUTE 送出的数据包不要利用路由设备来传输。
SO_BROADCAST 使用广播方式传送
SO_SNDBUF 设置送出的暂存区大小
SO_RCVBUF 设置接收的暂存区大小
SO_KEEPALIVE 定期确定连线是否已终止。
SO_OOBINLINE 当接收到OOB 数据时会马上送至标准输入设备
SO_LINGER 确保数据安全且可靠的传送出去。
       
参数
optval代表欲设置的值,参数optlen则为optval的长度。
       
返回值
成功则返回0,若有错误则返回-1,错误原因存于errno。
       
附加说明
EBADF 参数s并非合法的socket处理代码
ENOTSOCK 参数s为一文件描述词,非socket
ENOPROTOOPT 参数optname指定的选项不正确。
EFAULT 参数optval指针指向无法存取的内存空间。

 select是看你用FD_SET标记的若干个socket里面有没有event发生。
所谓的event发生就是这个socket受到了数据

如果这个socket是监听端口的,那么它收到数据意味着可能被connet了(受到了syn?),这时你应该accept,如果是已经建立的连接,受到了数据你就应该recv了。

如果这个函数返回了一个SOCKET_ERROR,那么有可能被切断了(socket读到了一个EOF?),你应该close。虽然SOCKET_ERROR有n种可能,但一般select如果失败了,你就可以把这个socket给断掉好了。可以看errno是多少号

select函数可以设等时,在这一定时间内如果没有任何数据,他会返回一个0,这时你再看着办,总比永远阻塞下去好。

节选自一个论坛,备用

你可能感兴趣的:(socket,网络)