pthread_detach - Détacher un thread
Bibliothèque de threads POSIX (
libpthread,
-lpthread)
#include <pthread.h>
int pthread_detach(pthread_t thread);
La fonction
pthread_detach() marque l'identifiant de thread
identifié par
thread comme détaché. Quand un
thread détaché se termine, ses ressources sont automatiquement
rendues au système sans avoir besoin d'un autre thread pour joindre le
thread terminé.
Essayer de détacher un thread qui est déjà
détaché résulte en un comportement indéfini.
En cas de réussite,
pthread_detach() renvoie 0 ; en cas
d'erreur, elle renvoie un numéro d'erreur.
- EINVAL
-
thread n'est pas un thread joignable.
- ESRCH
- Aucun fil d’exécution avec pour identifiant
thread n'a pu être trouvé.
Pour une explication des termes utilisés dans cette section, consulter
attributes(7).
Interface |
Attribut |
Valeur |
pthread_detach() |
Sécurité des threads |
MT-Safe |
POSIX.1-2001, POSIX.1-2008.
Une fois qu'un thread est détaché, il ne peut plus être
joint avec
pthread_join(3) ou être fait de nouveau joignable.
Un nouveau thread peut être créé dans un état
détaché en utilisant
pthread_attr_setdetachstate(3) pour
positionner l'attribut détaché de l'argument
attr de
pthread_create(3).
L'attribut d'état de détachement détermine principalement
le comportement du système quand le thread se termine. Il
n'empêche pas le thread de terminer si le processus se termine avec
exit(3) (ou, de manière équivalente, si le thread
principal sort de sa routine d'appel).
Soit
pthread_join(3), soit
pthread_detach() devrait être
appelé pour chaque thread créé par une application, afin
que les ressources système du thread puissent être
libérées. Notez cependant que les ressources de tous les threads
pour lesquels une de ces actions n'a pas été
réalisée sont libérées quand le processus se
termine.
L'expression suivante détache le thread appelant :
pthread_detach(pthread_self());
pthread_attr_setdetachstate(3),
pthread_cancel(3),
pthread_create(3),
pthread_exit(3),
pthread_join(3),
pthreads(7)
La traduction française de cette page de manuel a été
créée par Christophe Blaess
<
https://www.blaess.fr/christophe/>, Stéphan Rafin
<
[email protected]>, Thierry Vignaud
<
[email protected]>, François Micaux, Alain Portal
<
[email protected]>, Jean-Philippe Guérard
<
[email protected]>, Jean-Luc Coulon (f5ibh)
<
[email protected]>, Julien Cristau
<
[email protected]>, Thomas Huriaux <
[email protected]>,
Nicolas François <
[email protected]>, Florentin
Duneau <
[email protected]>, Simon Paillard
<
[email protected]>, Denis Barbier
<
[email protected]>, David Prévot <
[email protected]> et
Frédéric Hantrais <
[email protected]>
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 à
[email protected]