semget(2) は、セマフォの初期化またはセマフォへのアクセスを行います。呼び出しが成功すると、セマフォ ID (semid) を戻します。key 引数は、セマフォ ID に関連付けられた値です。nsems 引数は、セマフォ配列内の要素数を指定します。nsems が既存の配列の要素数を超える呼び出しは失敗します。正しい数がわからない場合は、この値を 0 に指定すると正しく実行されます。semflg 引数は、初期状態のアクセス権と作成の制御フラグを指定します。
SEMMNI システム構成オプションは、配列内のセマフォの最大許容数を指定します。SEMMNS オプションは、すべてのセマフォのセットを通じて個々のセマフォの最大数を指定します。セマフォのセット間のフラグメンテーションのため、利用できるすべてのセマフォを割り当てられない場合もあります。
次の例は、semget(2) を示しています。
#include <sys/types.h> #include <sys/ipc.h> #include <sys/sem.h> ... key_t key; /* semget() に渡す key */ int semflg; /* semget() に渡す semflg */ int nsems; /* semget() に渡す nsems */ int semid; /* semget() からの戻り値 */ ... key = ... nsems = ... semflg = ... ... if ((semid = semget(key, nsems, semflg)) == -1) { perror("semget: semget failed"); exit(1); } else exit(0); ... |