Man page - exit(3)

Packages contains this manual

Available languages:

en fr it pl ja ru ro zh_TW zh_CN de

Manual

exit

NOM
BIBLIOTHÈQUE
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ATTRIBUTS
STANDARDS
HISTORIQUE
NOTES
Signaux envoyĂ©s Ă  d’autres processus
VOIR AUSSI
TRADUCTION

NOM

exit - Terminer normalement un processus

BIBLIOTHÈQUE

BibliothĂšque C standard ( libc , -lc )

SYNOPSIS

#include <stdlib.h>

[[noreturn]] void exit(int status );

DESCRIPTION

La fonction exit () termine normalement un processus et l’octet de poids faible de statut (c’est-Ă -dire statut & 0xFF ) est envoyĂ© au processus parent (consultez wait (2)).

Toutes les fonctions enregistrĂ©es avec atexit (3) et on_exit (3) sont appelĂ©es dans l’ordre inverse de leur enregistrement. Il est possible pour une de ces fonctions d’utiliser atexit (3) ou on_exit (3) pour enregistrer une fonction supplĂ©mentaire Ă  exĂ©cuter lors de la procĂ©dure de terminaison ; le nouvel enregistrement est ajoutĂ© au dĂ©but de la liste des fonctions qui restent Ă  appeler. Si une de ces fonctions ne rend pas la main (car elle appelle _exit (2) ou se tue avec un signal par exemple), alors aucune des fonctions suivantes de la liste n’est exĂ©cutĂ©e et le processus de terminaison est abandonnĂ© (en particulier, le vidage des flux stdio (3)). Si une fonction a Ă©tĂ© enregistrĂ©e plusieurs fois avec atexit (3) ou on_exit (3), alors elle sera appelĂ©e aussi souvent qu’elle a Ă©tĂ© enregistrĂ©e.

Tous les flux ouverts du type stdio (3) sont vidés et fermés. Les fichiers créés par tmpfile (3) sont supprimés.

La norme C spĂ©cifie deux constantes EXIT_SUCCESS et EXIT_FAILURE qui peuvent ĂȘtre passĂ©es Ă  exit () pour indiquer respectivement une terminaison sans ou avec Ă©chec.

VALEUR RENVOYÉE

La fonction exit () ne renvoie jamais de valeur.

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes (7).

Image grohtml-3875354-1.png

La fonction exit () utilise une variable globale non protĂ©gĂ©e et n’est donc pas sĂ»re dans un contexte multithread.

STANDARDS

C11, POSIX.1-2008.

HISTORIQUE

C89, POSIX.1-2001, SVr4, 4.3BSD.

NOTES

Le comportement n’est pas dĂ©fini si une des fonctions enregistrĂ©es avec atexit (3) et on_exit (3) appelle exit () ou longjmp (3). Remarquez qu’un appel Ă  execve (2) supprime les enregistrements créés en utilisant atexit (3) et on_exit (3).

L’utilisation d’ EXIT_SUCCESS et d’ EXIT_FAILURE est lĂ©gĂšrement plus portable (vers des environnements non UNIX) que celle de zĂ©ro et d’une valeur non nulle comme 1 ou -1 . En particulier, le systĂšme VMS utilise une convention diffĂ©rente.

BSD a tenté de standardiser les codes de sortie (que certaines bibliothÚques C telles que la bibliothÚque C de GNU ont adoptés), consultez le fichier <sysexits.h> .

AprĂšs exit (), le statut doit ĂȘtre transmis au processus parent. Il y a trois cas :

-

Si le parent a positionnĂ© SA_NOCLDWAIT ou a positionnĂ© SIGCHLD Ă  SIG_IGN , le statut est abandonnĂ© et l’enfant meurt immĂ©diatement.

-

Si le parent attendait l’enfant, il est informĂ© du statut de sortie et l’enfant meurt immĂ©diatement.

-

Autrement, l’enfant devient un processus « zombie » : la plupart des ressources du processus sont rĂ©utilisĂ©es mais un emplacement contenant les informations minimales du processus enfant (statut de terminaison, statistiques d’utilisation des ressources) est conservĂ© dans la table de processus. Cela permet au parent d’utiliser par la suite waitpid (2) (ou similaire) afin de connaĂźtre le statut de terminaison de l’enfant ; aprĂšs quoi l’emplacement du processus « zombie » est libĂ©rĂ©.

Si l’implĂ©mentation gĂšre le signal SIGCHLD , celui-ci est envoyĂ© au processus parent. Si le parent a dĂ©fini SA_NOCLDWAIT , il n’est pas prĂ©cisĂ© si SIGCHLD est envoyĂ© ou non.

Signaux envoyĂ©s Ă  d’autres processus

Si le processus est un leader de session et si son terminal de contrĂŽle est le terminal de contrĂŽle de la session, alors chaque processus du groupe de processus en avant-plan de ce terminal reçoit un signal SIGHUP et le terminal est dissociĂ© de cette session, lui permettant d’ĂȘtre acquis par un nouveau processus de contrĂŽle.

Si la fin du processus rend orphelin un groupe de processus et si un membre quelconque de ce groupe de processus nouvellement orphelin est arrĂȘtĂ©, alors tous les processus de ce groupe vont recevoir SIGHUP suivi de SIGCONT . Consultez setpgid (2) pour plus d’informations sur les processus orphelins.

Mis Ă  part les cas susmentionnĂ©s, pour lesquels les processus ayant reçu un signal peuvent ĂȘtre des enfants du processus terminĂ©, la terminaison d’un processus ne cause pas en gĂ©nĂ©ral l’envoi d’un signal aux enfants de ce processus. Cependant, un processus peut utiliser l’opĂ©ration PR_SET_PDEATHSIG de prctl (2) pour faire en sorte qu’ils reçoivent un signal si le parent se termine.

VOIR AUSSI

_exit (2), get_robust_list (2), setpgid (2), wait (2), atexit (3), on_exit (3), tmpfile (3)

TRADUCTION

La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org> et Grégoire Scano <gregoire.scano@malloc.fr>

Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n’y a aucune RESPONSABILITÉ LÉGALE.

Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french@lists.debian.org .