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

Java Discussion :

Parallélisation de code


Sujet :

Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 61
    Points
    61
    Par défaut Parallélisation de code
    Bonjour,

    J'ai une application contenant plusieurs threads. J'ai une partie de mon code qui est executée par l'ensemble de mes threads mais pas en parallèle. Cela me fait perdre beaucoup en performance donc j'aurais aimé savoir si c'était possible de paralléliser cette partie. Voici le bout de code en question :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
    String ligne;
     
    while ((ligne = reader.readLine()) != null) {
    response.append(ligne);
    }
    Merci d'avance pour votre aide

  2. #2
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,



    C'est à dire ? Tu pourrais être plus précis ?

    Tu voudrais copier un même fichier via plusieurs threads ? rien que les mécanismes de synchronisation pourrait s'avérer beaucoup plus lourd


    a++

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 61
    Points
    61
    Par défaut
    Non en fait j'ai plusieurs threads qui effectuent une connection et récupèrent des données. Le problème est que quand le code s'execute tous les threads font leurs traitements en parallèle sauf la partie que j'ai mise plus haut qui a l'air d'être synchronisée. Du coup, les threads récupèrent leurs données à tour de rôle alors qu'il utilisent des objets "conn" différents donc je ne vois pas la nécessité : cela fait perdre beaucoup de temps.

    J'aurais voulu savoir s'il y avait une autre façon d'écrire ce code afin qu'il puisse etre executé en parallèle par tous mes threads.

  4. #4
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Août 2011
    Messages
    342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Août 2011
    Messages : 342
    Points : 1 091
    Points
    1 091
    Par défaut
    Il faut aussi que ta source de données supporte les accès en parallèle et qu'il n'y ait pas de bottleneck technique (du genre ta source est une base de données qui accède à un disque qui lui a un débit limité).

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 61
    Points
    61
    Par défaut
    Non ma source de données accepte bien les requetes en parallèle donc j'ai l'impression que ça vient du code mais je vois pas bien quoi...

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 190
    Points : 61
    Points
    61
    Par défaut
    Je peux me tromper mais je crois que la méthode getInputStream est "synchronized".

    Serait-ce possible d'utiliser une méthode équivalente qui ne le soit pas?

  7. #7
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Août 2011
    Messages
    342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Août 2011
    Messages : 342
    Points : 1 091
    Points
    1 091
    Par défaut
    Quelle est ta source de données ? S'il s'agit d'une socket getInputStream est effectivement synchronisée (au moins dans l'implémentation par défaut).

    De façon générale : je vois mal comment tu pourrais récupérer un InputStream différent à partir d'une même source. Comment serait consommée les données ?

    N'y aurait-il pas un problème de conception de ton code ? D'abord tu devrais avoir un lecteur qui consomme les data et ensuite les dispatch aux threads devant faire le boulot.

Discussions similaires

  1. [Oracle 10g] Paralléliser du code PL/SQL
    Par Yoh dans le forum Oracle
    Réponses: 3
    Dernier message: 06/05/2011, 12h07
  2. paralléliser un code en C++ ?
    Par membreComplexe12 dans le forum C++
    Réponses: 14
    Dernier message: 10/01/2011, 15h06
  3. Outils pour paralléliser du code Java
    Par LGnord dans le forum EDI et Outils pour Java
    Réponses: 3
    Dernier message: 12/07/2010, 10h01
  4. Paralléliser un morceau de code
    Par yann_m dans le forum Fortran
    Réponses: 7
    Dernier message: 09/10/2007, 12h48
  5. Parallélisation de code Java sur plusieurs machines
    Par Jester dans le forum API standards et tierces
    Réponses: 8
    Dernier message: 05/12/2006, 12h01

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