-
Créez un fil détaché lorsque vous savez que vous ne voudrez pas l'attendre avec
pthread_join()
. Le seul avantage en termes de performances est que lorsqu'un thread détaché se termine, ses ressources peuvent être libérées immédiatement au lieu d'avoir à attendre que le thread soit joint avant que les ressources puissent être libérées. -
Il est "légal" de ne pas rejoindre un fil joignable ; mais ce n'est généralement pas conseillé car (comme indiqué précédemment) les ressources ne seront pas libérées tant que le fil ne sera pas rejoint, elles resteront donc liées indéfiniment (jusqu'à la fin du programme) si vous ne le rejoignez pas.
Quand dois-je créer un fil comme détaché, dès le départ ?
Chaque fois que l'application ne se soucie pas du moment où ce thread se termine et ne se soucie pas non plus de sa valeur de retour d'un thread (un thread peut communiquer une valeur à un autre thread/application via pthread_exit
).
Par exemple, dans un modèle d'application client-serveur, un serveur peut créer un nouveau thread pour traiter chaque demande. Mais le serveur lui-même ne se soucie pas de la valeur de retour du thread. Dans ce cas, il est logique de créer détaché fils.
La seule chose dont le serveur doit s'assurer est que les requêtes en cours de traitement sont terminées. Ce qu'il peut faire, simplement en quittant le thread principal sans quitter l'ensemble du programme/de l'application. Lorsque le dernier thread du processus se termine, l'application/le programme se termine naturellement.
Le pseudocode pourrait ressembler à :
/* A server application */
void process(void *arg)
{
/* Detach self. */
pthread_detach(pthread_self());
/* process a client request. */
pthread_exit(NULL);
}
int main(void)
{
while (not_done) {
pthread_t t_id;
errno = pthread_create(&t_id, NULL, process, NULL);
if (errno) perror("pthread_create:");
}
/* There may be pending requests at this point. */
/* Just exit the main thread - not the whole program - so that remaining
requests that may still be processed can continue. */
pthread_exit(NULL);
}
Un autre exemple pourrait être un démon ou un thread de journalisation qui enregistre certaines informations à intervalles réguliers pendant toute la durée d'exécution de l'application.
Offre-t-il un avantage en termes de performances par rapport à un thread joignable ?
En termes de performances, il n'y a pas de différence entre joignable fils vs détachés fils. La seule différence est qu'avec les threads détachés, ses ressources (telles que la pile de threads et toute mémoire de tas associée, etc. - ce qui constitue exactement ces "ressources" sont spécifiques à l'implémentation).
Est-il légal de ne pas faire de pthread_join() sur un thread joignable (par défaut) ?
Oui, il est légal de ne pas rejoindre un fil de discussion. pthread_join
est une fonction pratique qui n'a en aucun cas besoin d'être utilisée, sauf si vous en avez besoin. Mais notez que les fils créés sont joignables fils par défaut.
Un exemple où vous voudrez peut-être vous joindre est lorsque les threads effectuent un "morceau" de travail qui est partagé entre eux. Dans ce cas, vous voudriez vérifier tous les threads complets avant de continuer. Le parallélisme des fermes de tâches en est un bon exemple.
Ou un tel thread devrait-il toujours utiliser la fonction detach() avant pthread_exit() ?
Pas nécessaire. Mais vous voudriez souvent décider si vous voulez un joignable ou détaché fil au moment de la création.
Notez qu'un fil détachable peut être créé en définissant l'attribut PTHREAD_CREATE_DETACHED
avec un appel au pthread_attr_setdetachstate
, un thread decide peut décider de se détacher à tout moment, par ex. avec pthread_detach(pthread_self())
. En outre, un thread qui a l'identifiant de thread (pthread_t
) d'un autre thread peut se détacher avec pthread_detach(thread_id);
.