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 :

question sur les threads en général


Sujet :

Python

  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Août 2013
    Messages
    274
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 274
    Points : 56
    Points
    56
    Par défaut question sur les threads en général
    bonjour,

    voila les threads permettent d'éxécuter plusieurs fonctions,class en parallèle . mais est ce que la lecture du programme se fait plus vite sans thread? car les threads c'est lire,exécuter une ligne d'une fonction et ensuite une autre ligne d'une autre fonction et ainsi de suite.

    mais si je met les deux fonctions en "série" ca prendre techniquement le meme temps, ou ca depend du nombre de coeur que possede notre processeur?

    j'aimerais savoir en gros si la programmation en parallèle permet d’exécuter le programme plus rapidement ou juste de travailler en parallèle ?

    merci pour vos éclaircissements

  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,

    Citation Envoyé par cosmoff Voir le message
    j'aimerais savoir en gros si la programmation en parallèle permet d’exécuter le programme plus rapidement ou juste de travailler en parallèle ?
    Pour faire simple, la programmation parallèle permet à votre application/programme d'utiliser le ou les CPUs à votre disposition.
    Votre application pourra aller plus vite si elle est plutôt gourmande en temps de calcul (et que vous avez réussi à paralléliser les traitements). Une application qui fait des ES disques ou réseau pourra aussi aller plus vite mais "parallèliser" sera différent et de toutes façons vous serez limité par le débit des disques, du réseau,...

    Avec le langage Python vous êtes contraint par le GIL: pas facile d'utiliser plus d'un CPU sans passer par le multiprocessing et pour maximiser l'utilisation d'un seul CPU, les coroutines seront plus efficaces que les threads.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Août 2013
    Messages
    274
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 274
    Points : 56
    Points
    56
    Par défaut
    est ce possible avec les threads de faiire ca:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     
    def programme1():
              choix = input("selectionner un chiffre")
     
    def programme2():
              print"1"
              time.sleep(2)
    si je fais ce programme, mon programme va bloquer dans le programme1 jusqu'a que choix est un chiffre.
    doonc finalement dans ce cas la, la programmationn en parallele est bof car ca n'exécutera jamais mon programme 2 non ?

  4. #4
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,

    Citation Envoyé par cosmoff Voir le message
    est ce possible avec les threads de faiire ca:
    ...
    Oui.

  5. #5
    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,

    Citation Envoyé par cosmoff Voir le message
    si je fais ce programme, mon programme va bloquer dans le programme1 jusqu'a que choix est un chiffre.
    doonc finalement dans ce cas la, la programmationn en parallele est bof car ca n'exécutera jamais mon programme 2 non ?
    Dans ce que vous montrez, programme1 et programme2 ne sont pas des programmes mais les fonctions d'un même programme. Vous pouvez lancer ces fonctions de façon séquentielle et les appels à raw_input ou time.sleep vont bloquer l'exécution ou de façon asynchrone (via des threads).
    Ceci dit, dans l'exemple que vous montrez, les activités (saisie d'une ligne de texte, afficher "1" et attendre 1 secondes) sont indépendantes: vous pourriez très bien en faire 2 programmes et les lancer indépendamment depuis la ligne de commande.
    Vous pourriez aussi utiliser un GUI graphique qui effectue la saisie et affiche simultanément le nombre de secondes écoulées jusqu'à ce que l'utilisateur appuie sur le bouton valider. Le GUI pourra réaliser cela "en parallèle" tout en utilisant un seul thread car saisir une entrée et afficher un nombre consomme peu de CPU et si on n'utilise pas des fonctions bloquantes, il y a de quoi faire.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Question sur les threads
    Par thebloodyman dans le forum Concurrence et multi-thread
    Réponses: 3
    Dernier message: 22/01/2007, 07h28
  2. Questions sur les threads: généralités
    Par Gragra dans le forum C++
    Réponses: 9
    Dernier message: 04/11/2006, 16h28
  3. Quelques questions sur les threads
    Par benj63 dans le forum C++Builder
    Réponses: 28
    Dernier message: 21/11/2005, 13h27
  4. Question sur les threads
    Par Linio dans le forum Concurrence et multi-thread
    Réponses: 10
    Dernier message: 21/10/2005, 09h08
  5. Question sur les threads
    Par nicolas66 dans le forum MFC
    Réponses: 4
    Dernier message: 03/06/2005, 20h57

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