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

Framework .NET Discussion :

Design accès exclusif TcpCLient


Sujet :

Framework .NET

  1. #1
    Membre émérite
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2006
    Messages
    1 627
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 627
    Points : 2 331
    Points
    2 331
    Par défaut Design accès exclusif TcpCLient
    Bonjour,

    je reprends un de mes vieux codes qui me donne pas satisfaction niveau design. J'ai 1..N Threads qui se partagent une connexion TcpClient. L'accès est exclusif, et j'essaie de prioriser les demandes d'écritures avant les demandes d'interrogations.

    Dans mon ancien design, chaque thread qui était en charge d'une action (lecture ou écriture, les lectures sont périodiques, les écritures ponctuelles) s'inscrivait dans une file, puis testait régulièrement si c'était son tour, faisait son office quand il avait la main puis faisait un sleep pour marquer une période d'interrogation...

    J'aimerais rendre l'accès plus dynamique. Je pensais utiliser les AutoResetEvent, que tous les threads soient en Wait et que celui qui ait fini de taffer fasse un Set, mais :
    * Comment gérer si j'ai un seul Thread ? AutoresetEvent tombe à l'eau alors, car personne ne pourra réveiller le thread
    * Comment gérer si le thread qui finit son taff fait le Set alors que les autres dorment et n'ont pas encore fait un Wait pour marquer leur désir de nouveau utiliser le TcpClient ?

    AutoResetEvent me semblait alléchant mais semble poser d'autres soucis de design. Si possible j'aimerais ne pas reposer sur des lock.

  2. #2
    Membre expérimenté

    Homme Profil pro
    Responsable des études
    Inscrit en
    Mars 2009
    Messages
    553
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2009
    Messages : 553
    Points : 1 672
    Points
    1 672
    Par défaut
    Hello, je n'ai jamais utilisé AutoResetEvent, mais de ce que j'ai pu comprendre:

    * Comment gérer si j'ai un seul Thread ? AutoresetEvent tombe à l'eau alors, car personne ne pourra réveiller le thread
    >> Ca implique que le tout premier Set doit être effectué par un autre thread, par exemple dès la création de l'AutoResetEvent:
    You can control the initial state of an AutoResetEvent by passing a Boolean value to the constructor: true if the initial state is signaled and false otherwise.
    Source: https://msdn.microsoft.com/fr-fr/lib...vs.110%29.aspx


    * Comment gérer si le thread qui finit son taff fait le Set alors que les autres dorment et n'ont pas encore fait un Wait pour marquer leur désir de nouveau utiliser le TcpClient ?
    >> L'AutoResetEvent mémorise le fait qu'un Set a été envoyé, mais pas encore consommé. Le prochain thread qui fera un WaitOne dessus consommera ce Set un s'exécutera immédiatement.
    A thread waits for a signal by calling WaitOne on the AutoResetEvent. If the AutoResetEvent is in the non-signaled state, the thread blocks, waiting for the thread that currently controls the resource to signal that the resource is available by calling Set.

    Calling Set signals AutoResetEvent to release a waiting thread.AutoResetEvent remains signaled until a single waiting thread is released, and then automatically returns to the non-signaled state. If no threads are waiting, the state remains signaled indefinitely.

    If a thread calls WaitOne while the AutoResetEvent is in the signaled state, the thread does not block. The AutoResetEvent releases the thread immediately and returns to the non-signaled state.

  3. #3
    Membre émérite
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2006
    Messages
    1 627
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 627
    Points : 2 331
    Points
    2 331
    Par défaut
    ok, j'avais mal interprété le AutorResetEvent, je pige mieux la différence avec le Manual !

    Merci

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

Discussions similaires

  1. HELP : pb de repartage de fichier apres un accès Exclusif
    Par gdecomb dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 27/07/2007, 10h41
  2. Acces exclusif fonction
    Par crevygood dans le forum Windows Forms
    Réponses: 7
    Dernier message: 06/06/2007, 14h04
  3. Un fichier a accés exclusif
    Par spekal dans le forum Administration système
    Réponses: 2
    Dernier message: 12/09/2006, 08h19
  4. Réponses: 5
    Dernier message: 11/12/2005, 17h36
  5. IPC : Files de messages et accès exclusif
    Par thomasvst dans le forum C
    Réponses: 2
    Dernier message: 07/12/2005, 09h47

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