SEM_GETVALUE

Section: Linux Programmer's Manual (3)
Updated: 2020-06-09
Index JM Home Page roff page
 

名前

sem_getvalue - セマフォの値を取得する  

書式

#include <semaphore.h>

int sem_getvalue(sem_t *sem, int *sval);

-pthread とリンクする。  

説明

sem_getvalue() は、 sem が指すセマフォの現在の値を sval で指す整数に格納する。

POSIX.1 によると、 1つ以上のプロセスかスレッドが sem_wait(3) でセマフォのロック待ちで停止している場合、 sval で返される値は 0 もしくは負の値のいずれかとなる。 負の値の場合、その絶対値は sem_wait(3) で現在停止しているプロセスかスレッドの合計数に等しい。 Linux は前者の動作 (0 を返す動作) を採用している。  

返り値

成功すると、 sem_getvalue() は 0 を返す。エラーの場合、-1 を返し、 errno にエラーを示す値をセットする。  

エラー

EINVAL
sem is not a valid semaphore. (The glibc implementation currently does not check whether sem is valid.)
 

属性

この節で使用されている用語の説明については、 attributes(7) を参照。
インターフェース属性
sem_getvalue() Thread safetyMT-Safe
 

準拠

POSIX.1-2001, POSIX.1-2008.  

注意

sem_getvalue() が返るときには、すでにセマフォの値は変化している可能性がある。  

関連項目

sem_post(3), sem_wait(3), sem_overview(7)  

この文書について

この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。


 

Index

名前
書式
説明
返り値
エラー
属性
準拠
注意
関連項目
この文書について

This document was created by man2html, using the manual pages.
Time: 16:46:42 GMT, November 24, 2023