マルチスレッドのプログラミング

pthread に相当するものがある同期関数 − セマフォ

セマフォの操作は Solaris オペレーティング環境と POSIX 環境の両方で同じです。関数名は、Solaris オペレーティング環境で sema_ だった関数名が pthread では sem_ に変わっています。

セマフォの初期化

sema_init(3THR)


#include <thread.h>

int sema_init(sema_t *sp, unsigned int count, int type,
    void *arg);

sema_init(3THR) は、sp が指すセマフォ変数に count の値を初期設定します。type には、次のいずれかを指定できます (arg は現在は無視されます)。

USYNC_PROCESS: 現在のプロセス内のスレッドと他のプロセス内のスレッドとの間で同期をとることができるようにします。ただし、セマフォを初期化するプロセスは 1 つだけに制限してください。arg は無視されます。

USYNC_THREAD: 現在のプロセス内のスレッドの間でだけ同期をとることができるようにします。arg は無視されます。

複数のスレッドから同じセマフォを同時に初期化してはいけません。一度初期化したセマフォは他のスレッドが使用している可能性があるので、再初期化してはいけません。

プロセス内スコープでのセマフォ


#include <thread.h>

sema_t sp;
int ret;
int count;
count = 4;

/* このプロセスの中だけで使用する */
ret = sema_init(&sp, count, USYNC_THREAD, 0); 

プロセス間スコープでのセマフォ


#include <thread.h>

sema_t sp;
int ret;
int count;
count = 4;

/* すべてのプロセスの間で使用する */
ret = sema_init (&sp, count, USYNC_PROCESS, 0); 

セマフォの加算

sema_post(3THR)


#include <thread.h>

int sema_post(sema_t *sp);

sema_post(3THR) は、sp が指すセマフォの値を原子操作によって 1 増やします。そのセマフォでブロックされているスレッドがある場合は、そのスレッドのうちの 1 つのスレッドがブロック解除されます。

セマフォの値によるブロック

sema_wait(3THR)


#include <thread.h>

int sema_wait(sema_t *sp);

sema_wait(3THR) は、sp が指すセマフォの値が、0 より大きくなるまでスレッドをブロックし、0 より大きくなったらセマフォの値を原子操作によって 1 減らします。

セマフォの減算

sema_trywait(3THR)


#include <thread.h>

int sema_trywait(sema_t *sp);

sema_trywait(3THR) は、sp が指すセマフォの値が 0 より大きい場合、原子操作によって 1 減らします。この関数はブロックしない点を除いて、sema_wait() と同じ働きをします。

セマフォの削除

sem_destroy(3RT)


#include <thread.h>

int sema_destroy(sema_t *sp);

sem_destroy(3RT) は、sp が指すセマフォを削除します。セマフォを格納する領域は解放されません。