oracular (3) pthread_sigqueue.3.gz

Provided by: manpages-ja-dev_0.5.0.0.20221215+dfsg-1_all bug

名前

       pthread_sigqueue - スレッドに対するシグナルとデータをキューに入れる

書式

       #include <signal.h>
       #include <pthread.h>

       int pthread_sigqueue(pthread_t thread, int sig,
                            const union sigval value);

       -pthread を付けてコンパイルとリンクを行う。

   glibc 向けの機能検査マクロの要件 (feature_test_macros(7)  参照):

       pthread_sigqueue(): _GNU_SOURCE

説明

       pthread_sigqueue()  関数は  sigqueue(3)  と同様の処理を実行するが、  プロセスにシグナルを送信するのではな
       く、呼び出したスレッドと 同じプロセス内のスレッドにシグナルを送信する。

       thread 引数は、呼び出し側と同じプロセスのスレッドの ID  である。  sig  引数は送信するシグナルを指定する。
       value 引数はシグナルと一緒に渡すデータを指定する。 詳細は sigqueue(3) を参照。

返り値

       成功すると、 pthread_sigmask() は 0 を返す。 エラーの場合、エラー番号を返す。

エラー

       EAGAIN キューに入れられるシグナル数が上限に達していた (詳しい情報は (signal(7) を参照)。

       EINVAL sig が無効であった。

       ENOSYS pthread_sigqueue() がこのシステムではサポートされていない。

       ESRCH  thread が無効である。

バージョン

       pthread_sigqueue() 関数は glibc 2.11 で初めて登場した。

属性

       この節で使用されている用語の説明については、 attributes(7) を参照。

       ┌───────────────────┬───────────────┬─────────┐
       │インターフェース属性      │
       ├───────────────────┼───────────────┼─────────┤
       │pthread_sigqueue() │ Thread safety │ MT-Safe │
       └───────────────────┴───────────────┴─────────┘

準拠

       この関数は GNU による拡張である。

注意

       The  glibc  implementation  of pthread_sigqueue()  gives an error (EINVAL)  on attempts to send either of
       the real-time signals used internally by the NPTL threading implementation.  See nptl(7)  for details.

関連項目

       rt_tgsigqueueinfo(2), sigaction(2), pthread_sigmask(3), sigqueue(3), sigwait(3), pthreads(7), signal(7)

この文書について

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