#include <stdlib.h> void exit(int status);
atexit(3) や on_exit(3) によって 登録された全ての関数は、それらが登録された順番と逆順にコールされる。 (登録された関数の中で atexit(3) or on_exit(3) を使って exit 処理中に実行される追加の関数を登録することができる; 新規に登録された関数は、この後で実行される関数リストの先頭に 追加される。) これらの関数の一つが返らなかった場合 (例えば、その関数が _exit(2) を呼び出したり、シグナルで自分自身を kill した場合)、 残りの関数はどれも呼び出されず、それ以降の exit 処理 (特に stdio(3) ストリームのフラッシュなど) は中止される。 ある関数が atexit(3) や on_exit(3) を使って複数回登録されていた場合、 その関数は登録されたのと同じ回数だけ呼び出される。
オープン中の stdio(3) ストリームは全てフラッシュされて、クローズされる。 tmpfile(3) によって作成されたファイルは削除される。
C 標準では EXIT_SUCCESS と EXIT_FAILURE という 2つの定数が 定義されている。それぞれ正常終了と異常終了を示すもので、 exit() として渡すことができる。
インターフェース | 属性 | 値 |
exit() | Thread safety | MT-Unsafe race:exit |
exit() 関数は保護されていないグローバル変数を使用しているため、スレッドセーフではない。
EXIT_SUCCESS と EXIT_FAILURE を使うと、0 や (1 や -1 といった) 0 以外の値を使うのに比べて (UNIX 以外の環境に) 移植するのがいくらか簡単になる。 特に VMS は別の方式を用いている。
BSD は終了コードを標準化しようとしている (GNU C ライブラリなどのいくつかの C ライブラリもこれを採用している); <sysexits.h> を参照すること。
After exit(), the exit status must be transmitted to the parent process. There are three cases:
SIGCHLD シグナルのサポートが実装されている場合、 このシグナルは親プロセスに送られる。 親プロセスが SA_NOCLDWAIT を設定した場合、 SIGCHLD シグナルが送られるかどうかは定義されていない。
プロセスが終了することにより、プロセスグループが孤立して、 そのグループのメンバーのうちのどれかが停止した場合、 プロセスグループの各プロセスに対して SIGHUP シグナルが送られ、続いて SIGCONT シグナルが送られる。 孤立した (orphaned) プロセスグループの説明は setpgid(2) を参照。
Except in the above cases, where the signalled processes may be children of the terminating process, termination of a process does not in general cause a signal to be sent to children of that process. However, a process can use the prctl(2) PR_SET_PDEATHSIG operation to arrange that it receives a signal if its parent terminates.
[man1]
[man2]
[man3]
[man4]
[man5]
[man6]
[man7]
[man8]
[a]
[b]
[c]
[d]
[e]
[f]
[g]
[h]
[i]
[j]
[k]
[l]
[m]
[n]
[o]
[p]
[q]
[r]
[s]
[t]
[u]
[v]
[w]
[x]
[y]
[z]