函数原型: #include <sys/types.h> #include <sys/socket.h> int setsockopt(int sockfd,
int level, int optname, const void *optval, socklen_t optlen); sockfd: 标识一个套接口的描述字 level: 选项定 义的层次;支持SOL_SOCKET、IPPROTO_TCP、IPPROTO_IP和IPPROTO_IPV6 optname:需设置的选项 optval: 指针,指向存放选项值的缓冲区 optlen: optval缓冲区长度 全部都必须要放在bind之前,另外通常是用于UDP的。 |
1. 如果在已经处于 ESTABLISHED状态下的socket(一般由端口号和标志符区分)调用closesocket(一般不会立即关闭而经历TIME_WAIT的过程)后想继续重用该socket:(程序里不要写close关闭描述符,其实写不写都无所谓,这里设置了可以重用) int reuse=1; 默认这个值是0 setsockopt(s,SOL_SOCKET ,SO_REUSEADDR,(const char*)&reuse,sizeof(int)); 2. 如果要已经处于连接状态的soket在调用closesocket后强制关闭,不经历TIME_WAIT的过程: int reuse=0;(前面写代码,后面反复用同一个端口他就会直接perror说端口占用) setsockopt(s,SOL_SOCKET ,SO_REUSEADDR,(const char*)&reuse,sizeof(int)); 3. 在send(),recv()过程中有时由于网络状况等原因,发收不能预期进行,而设置收发时限: int nNetTimeout=1000; // 1秒 // 发送时限,到了设定时间对方还没有收到就重发 setsockopt(socket,SOL_S0CKET,SO_SNDTIMEO,(void*)&nNetTimeout,sizeof(int)); // 接收时限 setsockopt(socket,SOL_S0CKET,SO_RCVTIMEO,(void*)&nNetTimeout,sizeof(int)); 4. 在send()的时候,返回的是实际发送出去的字节(同步)或发送到socket缓冲区的字节(异步),系统默认的状态发送和接收一次为8688字节(约为8.5K);在实际的过程中发送数据和接收数据量比较大,可以设置socket缓冲区,而避免了send(),recv()不断的循环收发: // 接收缓冲区 (默认都是64K) int nRecvBuf=32*1024; // 设置为32K setsockopt(s,SOL_SOCKET,SO_RCVBUF,(const char*)&nRecvBuf,sizeof(int)); // 发送缓冲区 int nSendBuf=32*1024; // 设置为32K setsockopt(s,SOL_SOCKET,SO_SNDBUF,(const char*)&nSendBuf,sizeof(int)); 5. 如果在发送数据时,希望不经历由系统缓冲区到socket缓冲区的拷贝而影响程序的性能: int nZero=0; setsockopt(socket,SOL_SOCKET,SO_SNDBUF,(char *)&nZero,sizeof(int)); 6. 同上在recv()完成上述功能(默认情况是将socket缓冲区的内容拷贝到系统缓冲区): int nZero=0; setsockopt(socket,SOL_SOCKET,SO_RCVBUF,(char *)&nZero,sizeof(int)); 7. 一般在发送UDP数据报的时候,希望该socket发送的数据具有广播特性: int bBroadcast= 1; setsockopt(s,SOL_SOCKET,SO_BROADCAST,(const char*)&bBroadcast,sizeof(int)); |