GNU/Linux >> Tutoriels Linux >  >> Linux

Threads POSIX détachés ou joignables

  1. 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.

  2. 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); .


Linux
  1. Qu'est-ce que Posix exactement ?

  2. Introduction aux threads Linux – Partie I

  3. Comment créer des threads sous Linux (avec un exemple de programme C)

  4. Comment nommer un thread sous Linux ?

  5. Est-ce que errno est thread-safe ?

Quel Bash est en cours d'exécution ?

Tuer la session d'écran détaché

Threads préemptifs vs threads non préemptifs

ID de thread vs poignée de thread

Traitement du signal avec plusieurs threads sous Linux

Est-ce que fopen() est une fonction thread-safe sous Linux ?