IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Threads & Processus C++ Discussion :

Dans quels cas est-on obligés d'utiliser des mutex ?


Sujet :

Threads & Processus C++

  1. #1
    Membre régulier Avatar de kidpaddle2
    Inscrit en
    Avril 2006
    Messages
    430
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 430
    Points : 95
    Points
    95
    Par défaut Dans quels cas est-on obligés d'utiliser des mutex ?
    Bonjour,

    Tout est dans le titre. J'aimerais en particulier vérifier quelque chose : j'ai une instance de classe dans le main. Cette classe lance un thead qui va être LE SEUL à lire/écrire dans la classe. A-t-on besoin de faire du thread-safe pour une pareille utilisation ?

    Bien entendu, si vous pouviez me résumer dans quels cas est-on obligés de faire attention au thread-safe, j'apprécierais beaucoup.

    Merci d'avance.

    Cordialement,

    Kidpaddle2

  2. #2
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Points : 16 213
    Points
    16 213
    Par défaut
    Pour moi, on a toujours besoin de faire du thread-safe. La fait de dire qu'un objet sera utilisé dans un thread et un seul, et qu'il n'a donc besoin d'aucune fonction de protection (comme des mutex) est une manière de faire du thread safe (qui a l'avantage d'être aisée à mettre en œuvre, et peu coûteuse en ressource. C'est en fait probablement la meilleure manière de faire, quand ça a du sens).

    Des fonctions de protection contre un accès concurrent sont nécessaires lorsqu'une ressource va être utilisée en même temps par plusieurs threads, et qu'un de ces threads au moins va modifier cette ressource (et sauf si accès et modification sont effectuée de manière atomique).

  3. #3
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Points : 13 017
    Points
    13 017
    Par défaut
    Bonsoir,
    Citation Envoyé par JolyLoic Voir le message
    Des fonctions de protection contre un accès concurrent sont nécessaires lorsqu'une ressource va être utilisée en même temps par plusieurs threads, et qu'un de ces threads au moins va modifier cette ressource (et sauf si accès et modification sont effectués de manière atomique).
    Je me permet de rebondir car j'ai souvent vu l'utilisation de mutex pour se protéger d'un accès concurrent 'à risque' en pensant que ce mutex allait résoudre d'un coup les problèmes de concurrence.
    Or le mutex n'est là, si on résume, que pour rendre 'atomique' une opération qui ne l'est pas au départ. Or il faut faire attention à avoir une conception qui soit aussi pensée dans un cadre de concurrence. Un classique (liée à des conceptions bancales justement) est le mélange d'échange entre thread à la fois par un mécanisme de message/boîte aux lettres et la lecture ou la modification d'état par fonction. On peut avoir des comportements totalement erratiques en fonction des politiques d'ordonnancement, des contextes d'exécution, etc. Tout simplement parce qu'un message sera reçu avant ou après l'accès à une fonction alors qu'on attendait à ce que le traitement soit déjà en cours.
    Tout ça pour dire qu'il me semble qu'on tend aujourd'hui à minimiser les partages de données entre différents threads au profit de mécanisme d'échange de type boîtes aux lettres (cf les articles de Herb Sutter et Use Threads Correctly = Isolation + Asynchronous Messages et Prefer Using Active Objects Instead of Naked Threads par exemple)

  4. #4
    Membre régulier Avatar de kidpaddle2
    Inscrit en
    Avril 2006
    Messages
    430
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 430
    Points : 95
    Points
    95
    Par défaut
    Merci pour vos réponses, j'avais un doute. =)

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 09/03/2013, 10h10
  2. Réponses: 14
    Dernier message: 03/04/2008, 01h44
  3. Réponses: 3
    Dernier message: 24/04/2007, 23h42
  4. [Zope] Dans quel cas utiliser zope ?
    Par kalimero dans le forum Zope
    Réponses: 3
    Dernier message: 26/07/2005, 09h08
  5. [corba] débutant : dans quels cas l'utiliser
    Par jmturc dans le forum CORBA
    Réponses: 2
    Dernier message: 10/10/2002, 08h58

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo