_exit(2) System Calls Manual _exit(2) NOM _exit, _Exit - Mettre fin au processus appelant BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include [[noreturn]] void _exit(int status); #include [[noreturn]] void _Exit(int status); Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : _Exit() : _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L DESCRIPTION La fonction _exit() met fin << immediatement >> au processus en cours, les descripteurs de fichier lui appartenant sont fermes, tous ses enfants eventuels sont recuperes par le processus init(1) (ou par le processus << subreaper >> le plus proche comme defini a l'aide de l'utilisation de l'operation PR_SET_CHILD_SUBREAPER de prctl(2)). Le processus parent recoit un signal SIGCHLD. La valeur status & 0xFF est renvoyee au processus parent comme valeur de sortie et peut etre recuperee en utilisant un appel systeme de la famille wait(2). La fonction _Exit() est equivalente a _exit(). VALEUR RENVOYEE Ces fonctions ne renvoient rien. STANDARDS _exit() POSIX.1-2008. _Exit() C11, POSIX.1-2008. HISTORIQUE POSIX.1-2001, SVr4, 4.3BSD. La fonction _Exit() a ete introduite par C99. NOTES Pour une discussion sur les effets de exit, la transmission du code de retour, les processus zombie, les signaux envoyes, etc., reportez-vous a exit(3). L'appel systeme _exit() est identique a exit(3), mais n'appelle aucune fonction programmee par atexit(3) ou on_exit(3). Les flux stdio(3) ne sont pas vides. D'un autre cote, _exit() ferme les descripteurs de fichier ouverts, ce qui peut retarder son execution durant le temps ou des sorties se terminent. Si ce retard est genant, on peut invoquer des fonctions telles que tcflush(3) avant d'appeler _exit(). Savoir si toutes les entrees-sorties en attente sont annulees, et lesquelles sont annulees lors d'un _exit(), depend de l'implementation. Differences entre bibliotheque C et noyau Le texte de la DESCRIPTION ci-dessus decrit l'effet traditionnel de _exit(), qui est de terminer un processus et il s'agit de la semantique specifiee par la POSIX.1 et implementee par la fonction enveloppe de la bibliotheque C. Sur des systemes modernes, cela signifie la fin de tous les processus. Contrairement a la fonction enveloppe de la bibliotheque C, l'appel systeme _exit() brut de Linux ne termine que le thread appelant et il ne reapparente un processus enfant ou n'envoie un signal SIGCHLD au processus parent que s'il s'agit du dernier thread du groupe de threads. Jusqu'a la glibc 2.3, la fonction enveloppe _exit() appelait l'appel systeme de meme nom. Depuis la glibc 2.3, la fonction enveloppe appelle exit_group(2), afin de terminer tous les processus legers du processus. VOIR AUSSI execve(2), exit_group(2), fork(2), kill(2), wait(2), wait4(2), waitpid(2), atexit(3), exit(3), on_exit(3), termios(3) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot et Jean-Philippe MENGUAL Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.8 2 mai 2024 _exit(2)