getsockopt( )関数の詳細

getsockopt()関数は、ソケットのオプションの現在の値を取得するために使用されます。

int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen);

パラメーターの説明:

  1. ソケットファイル記述子(sockfd)。
  2. レベル:オプションのプロトコルレイヤー。
  3. 選択肢:選択肢の名前。
  4. optval:選択肢の値を格納するための出力パラメータ。
  5. optlen: optvalバッファのサイズを指定し、実際に取得されたオプション値の長さを返します。

戻り値:

  1. 成功: 0 (Seikou: zero)
  2. 失敗時: -1を返し、errnoを設定します。

一般のレベルとオプション名のパラメータ:

  1. levelがSOL_SOCKETの場合のオプション:SO_SNDBUF:送信バッファサイズ。
    SO_RCVBUF:受信バッファサイズ。
    SO_REUSEADDR:アドレスの再利用を許可する。
  2. 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アルゴリズムの状態を取得します。

bannerAds