正在加载……
专注、离线、切勿分心

函数原型:

#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_SOCKETIPPROTO_TCPIPPROTO_IPIPPROTO_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(socketSOL_S0CKET,SO_SNDTIMEO(void*)&nNetTimeout,sizeof(int));

// 接收时限

setsockopt(socketSOL_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(socketSOL_SOCKET,SO_SNDBUF(char *)&nZero,sizeof(int));

6. 同上在recv()完成上述功能(默认情况是将socket缓冲区的内容拷贝到系统缓冲区)

int nZero=0;

setsockopt(socketSOL_SOCKET,SO_RCVBUF(char *)&nZero,sizeof(int));

7. 一般在发送UDP数据报的时候,希望该socket发送的数据具有广播特性:

int bBroadcast= 1;

setsockopt(s,SOL_SOCKET,SO_BROADCAST,(const char*)&bBroadcast,sizeof(int));






posted on 2018-03-28 08:42  正在加载……  阅读(390)  评论(0编辑  收藏  举报