#include <netdb.h> struct servent *getservent(void); struct servent *getservbyname(const char *name, const char *proto); struct servent *getservbyport(int port, const char *proto); void setservent(int stayopen); void endservent(void);
getservbyname() 関数は、 プロトコル proto を用いるサービスの名前 name にマッチするエントリーをデータベースから探し、 そのエントリーを収めた servent 構造体を返す。 proto が NULL の場合は、任意のプロトコルにマッチする。 必要であれば、データベースへの接続がオープンされる。
getservbyport() 関数は、 プロトコル proto を用いるサービスのポート番号 port にマッチするエントリーをデータベースから探し、 そのエントリーの内容を収めた servent 構造体を返す (ポート番号 port はネットワークバイトオーダで指定する)。 proto が NULL の場合は任意のプロトコルにマッチする。 必要であれば、データベースへの接続がオープンされる。
setservent() 関数はデータベースへの接続をオープンし、 次の読み込みエントリーを先頭のエントリーに設定する。 stayopen が 0 でない場合、 一つ一つの getserv*() 関数の呼び出し間でデータベースへの接続をクローズしない。
endservent() 関数はデータベースへの接続をクローズする。
servent 構造体は <netdb.h> で以下のように定義されている。
struct servent {
char *s_name; /* official service name */
char **s_aliases; /* alias list */
int s_port; /* port number */
char *s_proto; /* protocol to use */ }
servent 構造体のメンバーは以下の通り。
Interface | Attribute | Value |
getservent() | Thread safety | MT-Unsafe race:servent race:serventbuf locale |
getservbyname() | Thread safety | MT-Unsafe race:servbyname locale |
getservbyport() | Thread safety | MT-Unsafe race:servbyport locale |
setservent(), endservent() |
Thread safety | MT-Unsafe race:servent locale |
In the above table, servent in race:servent signifies that if any of the functions setservent(), getservent(), or endservent() are used in parallel in different threads of a program, then data races could occur.
[man1]
[man2]
[man3]
[man4]
[man5]
[man6]
[man7]
[man8]
[a]
[b]
[c]
[d]
[e]
[f]
[g]
[h]
[i]
[j]
[k]
[l]
[m]
[n]
[o]
[p]
[q]
[r]
[s]
[t]
[u]
[v]
[w]
[x]
[y]
[z]