getsockopt( )関数の詳細
getsockopt()関数は、ソケットのオプションの現在の値を取得するために使用されます。
int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen);
パラメーターの説明:
- ソケットファイル記述子(sockfd)。
- レベル:オプションのプロトコルレイヤー。
- 選択肢:選択肢の名前。
- optval:選択肢の値を格納するための出力パラメータ。
- optlen: optvalバッファのサイズを指定し、実際に取得されたオプション値の長さを返します。
戻り値:
- 成功: 0 (Seikou: zero)
- 失敗時: -1を返し、errnoを設定します。
一般のレベルとオプション名のパラメータ:
- levelがSOL_SOCKETの場合のオプション:SO_SNDBUF:送信バッファサイズ。
SO_RCVBUF:受信バッファサイズ。
SO_REUSEADDR:アドレスの再利用を許可する。 - levelがIPPROTO_TCPであるオプション:TCP_KEEPIDLE:TCP接続がアイドル状態になったときのタイムアウト時間。
TCP_KEEPINTVL:TCPキープアライブ探査の間隔。
TCP_NODELAY:Nagleアルゴリズムを無効化する。
サンプルコード:
#include <stdio.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/tcp.h>
int main() {
int sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
perror("socket");
return 1;
}
int sndbuf;
socklen_t len = sizeof(sndbuf);
int ret = getsockopt(sockfd, SOL_SOCKET, SO_SNDBUF, &sndbuf, &len);
if (ret == 0) {
printf("SO_SNDBUF: %d\n", sndbuf);
} else {
perror("getsockopt");
}
int nodelay;
len = sizeof(nodelay);
ret = getsockopt(sockfd, IPPROTO_TCP, TCP_NODELAY, &nodelay, &len);
if (ret == 0) {
printf("TCP_NODELAY: %d\n", nodelay);
} else {
perror("getsockopt");
}
close(sockfd);
return 0;
}
上記のコードは、ソケットの送信バッファサイズとNagleアルゴリズムの状態を取得します。