Provided by: manpages-ja-dev_0.5.0.0.20131015+dfsg-2_all bug

名前

       getpid, getppid - プロセス ID を得る

書式

       #include <sys/types.h>
       #include <unistd.h>

       pid_t getpid(void);
       pid_t getppid(void);

説明

       getpid()   は呼び出し元のプロセスのプロセス ID を返す。(テンポラリ用のファイル名として 他と重ならない名前
       を生成するルーチンでしばしば使用される。)

       getppid()  は呼び出し元のプロセスの親プロセスのプロセス ID を返す。

エラー

       これらの関数は常に成功する。

準拠

       POSIX.1-2001, 4.3BSD, SVr4.

注意

       glibc バージョン 2.3.4 以降では、 glibc の getpid()  のラッパー関数は PID をキャッシュする。 これは、プロ
       セスが繰り返し  getpid()  を呼び出した場合にその都度システムコールを呼ぶのを避けるためである。 通常は、こ
       のキャッシュ処理が見えることはないが、 キャッシュ処理が正しく働くためには fork(2), vfork(2), clone(2)  の
       ラッパー関数でのサポートが必要である。  アプリケーションがこれらのシステムコールを呼び出す際に、 glibc の
       ラッパー関数を経由せずに syscall(2)  を使った場合には、子プロセスで getpid() を呼び出すと間違った値が返る
       ことだろう  (正確にいうと、親プロセスの PID が返される)。 clone(2)  を glibc のラッパー関数経由で起動した
       際にも getpid()  が間違った値を返す場合があり、これに関する議論は clone(2) も参照してほしい。

関連項目

       clone(2), fork(2), kill(2), exec(3), mkstemp(3), tempnam(3), tmpfile(3), tmpnam(3), credentials(7)

この文書について

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