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

Delphi Discussion :

Verrouillage multiple et threading


Sujet :

Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 17
    Par défaut Verrouillage multiple et threading
    J'ai un petit casse-tête logique sur l'appli sur laquelle je travaille :
    - J'ai une grande collection d'objets en mémoire (représentant des fichiers)
    - J'ai plusieurs threads qui travaillent sur ces objets (un seul par thread ou plusieurs en même temps parfois), avec des accès lecture ou lecture/écriture

    J'ai donc besoin de verouiller ces objets pour éviter les conflits. La solution évidente serait de coller un mutex/sémaphore dans chaque objet, mais comme j'ai pas mal d'objets cela risque de faire beaucoup de sémaphores. Je cherche donc une solution permettant de verouiller un objet sur lequel travaille une thread (en faisant patienter une autre qui voudrait aussi y accéder) mais relativement économes en objets de synchro (mutex, sémaphores, évènements, sections critiques, que sais-je ?)

  2. #2
    Expert confirmé

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Par défaut
    Les sections critiques sont faites pour ça : voir TCriticalSection dans l'aide en ligne
    sjrd, ancien rédacteur/modérateur Delphi.
    Auteur de Scala.js, le compilateur de Scala vers JavaScript, et directeur technique du Scala Center à l'EPFL.
    Découvrez Mes tutoriels.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 17
    Par défaut
    Citation Envoyé par sjrd
    Les sections critiques sont faites pour ça : voir TCriticalSection dans l'aide en ligne
    Cela revient au même qu'avec les mutex/semaphores : il me faudrait X sections critiques pour X objets, ce que je veux justement éviter car X est relativement grand.

    En fait je ne cherche pas à synchroniser un passage d'information d'une thread à l'autre mais à sécuriser des objets contre des accès concurrents. Par exemple il existe un "Canvas.Lock" et un "Canvas.Unlock" et je veux obtenir la même fonctionnalité pour mes objets, mais sans créer un mutex dans chacun.

Discussions similaires

  1. Multiple thread peuvent ils bloquer (EDT) malgre invokeLater
    Par murgen23 dans le forum EDT/SwingWorker
    Réponses: 3
    Dernier message: 12/09/2008, 07h56
  2. Multiples threads vb.net
    Par tlibert dans le forum VB.NET
    Réponses: 9
    Dernier message: 27/02/2007, 13h14
  3. [Thread] Accès multiples disque dur
    Par Djakisback dans le forum Concurrence et multi-thread
    Réponses: 2
    Dernier message: 21/05/2006, 13h46
  4. Réponses: 2
    Dernier message: 31/10/2005, 14h29
  5. Thread de code indentique Multiples
    Par Cambon dans le forum Bases de données
    Réponses: 1
    Dernier message: 30/05/2005, 14h20

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