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

Python Discussion :

Partage de Queue entre module


Sujet :

Python

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Mai 2013
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Mai 2013
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Partage de Queue entre module
    Bonsoir à tous,

    Je suis face à un problème épineux pour moi, mais je pense que je loupe simplement quelque chose et je souhaitez avoir votre aide.

    J'ai un programme organisé entre plusieurs module et j'aimerais avoir une queue qui les relis.

    l'arborescence de mon projet est la suivante :
    /game/
    -------/__init__.py
    -------/server.py
    -------/client.py
    prog.py

    le code de prog.py :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
     
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    import random,time,threading
    try:
    	import Queue
    except ImportError:
    	import queue as Queue
     
    from game import server,client
    enStock = Queue.Queue(0)
     
    server.Server().start()
     
    for i in range(3):
    	client.Client().start()
     
    try:
    	time.sleep(30)
    except (KeyboardInterrupt, SystemExit):
    	pass
    le code de server.py :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    import time,threading
    try:
    	import Queue
    except ImportError:
    	import queue as Queue
     
    class Server(threading.Thread):
    	def __init__(self):
    		threading.Thread.__init__(self)
    		self.daemon = True
     
    	def run(self):
    		while True:
    			print(enStock.get(True))
    le code de client.py :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    import time,threading
    try:
    	import Queue
    except ImportError:
    	import queue as Queue
     
    class Client(threading.Thread):
    	def __init__(self):
    		threading.Thread.__init__(self)
    		self.daemon = True
     
    	def run(self):
    		while True:
    			enStock.put('test',True,None)
    			time.sleep(1)
    Mais forcément les modules n'arrivent pas à accéder à la queue "enStock"....
    J'ai essayer de le mettre dans le __init__.py, de faire "global enStock" , de faire plusieurs déclarations, d'y accéder en tant que attribut du module, mais rien n'y fait, je ne trouve pas comment faire :/

    Quelqu'un aurez une idée comment je pourrais résoudre ça ?
    Merci d'avance!

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Pourquoi ne pas écrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    enStock = Queue.Queue(0)
     
    server.Server(enStock).start()
     
    for i in range(3):
    	client.Client(enStock).start()
    Puis:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    class Server(threading.Thread):
    	def __init__(self, enStock):
                    ...
                    self.enStock = enStock
    	def run(self):
    		while True:
    			print(self.enStock.get(True))
    Pourquoi faire de server une s/classe de threading.Thread plutôt qu'une fonction?
    On aurait alors:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    def server(enQueue):
    	while True:
    		print(enStock.get(True))
    Lancé par:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    p = threading.Thread(target=server, args=(enQueue))
    p.daemon = True
    p.start()
    Le boulot de Server est dans sa méthode .run. Il devrait pouvoir se faire de façon analogue lancé dans un thread séparé ou pas. Ca permet de le tester simplement et de s'assurer qu'il fonctionne sans "threads" avant de se compliquer la vie avec des threads.
    En plus, passer enQueue en paramètre d'une fonction est quand même plus simple que de le passer au constructeur pour en faire un attribut qui pourra être utilisé par la (seule) méthode qui le mérite.
    A vous de voir.
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Partager CONST entre modules de classes
    Par cerise dans le forum Général VBA
    Réponses: 7
    Dernier message: 31/01/2012, 16h37
  2. [langage] Probleme passage de variables entre modules
    Par Ludo167 dans le forum Langage
    Réponses: 4
    Dernier message: 13/08/2004, 12h25
  3. [Forms] : Gestion de Navigation entre module
    Par patmaba dans le forum Forms
    Réponses: 12
    Dernier message: 09/04/2004, 14h09
  4. Réponses: 3
    Dernier message: 30/03/2004, 09h38
  5. [Designer] Problème de transfert de données entre modul
    Par BILLYPATOU dans le forum Designer
    Réponses: 11
    Dernier message: 09/03/2004, 18h15

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