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

Entrée/Sortie Java Discussion :

Optimisation Lecture de fichiers


Sujet :

Entrée/Sortie Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Inscrit en
    Mars 2006
    Messages
    126
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 126
    Par défaut Optimisation Lecture de fichiers
    Bonjour,

    J'ai un traitement qui lit plusieurs fichiers et qui fait des traitements sur les données lues.
    Le traitement est tres long, car je lis un fichier, je passe au suivant, etc...

    Est-ce qu'il y aurai un autre moyen plus rapide d'effectuer ce traitement, comme par exemple lancer plusieurs threads en même temps.

    Jusqu'à combien de thread peut-on lancer en même temps ?

    Merci

  2. #2
    Membre Expert
    Avatar de Patriarch24
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Septembre 2003
    Messages
    1 047
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 047
    Par défaut
    Jusqu'à combien de thread peut-on lancer en même temps ?
    Autant que l'OS sous-jacent peut en supporter.
    En général, ce n'est pas la solution de lancer beaucoup de threads, il y a un seuil au delà duquel les performances chutent, après avoir augmenté. Le mieux pour améliorer les performances est d'améliorer l'algorithme (accès aux données), d'utiliser des entrées/sorties bufferisées, etc.

  3. #3
    Rédacteur
    Avatar de CyberChouan
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    2 752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 752
    Par défaut
    Je suis d'accord avec Patriarch24 !

    j'ajouterai que pour gérer correctement les threads, le mieux est d'en fixer un nombre maximal (pour ne pas dégrader les performances), et de gérer l'enchaînement des traitements sur ces threads par un mécanisme de "pool de threads", qui s'occupera d'ordonnancer les traitements.

    Par exemple, depuis Java 5 : ThreadPoolExecutor
    Avant de poster, pensez à regarder la FAQ, les tutoriaux, la Javadoc (de la JRE que vous utilisez) et à faire une recherche
    Je ne réponds pas aux questions techniques par MP: les forums sont faits pour ça
    Mes articles et tutoriaux & Mon blog informatique

  4. #4
    Membre très actif
    Inscrit en
    Mars 2006
    Messages
    126
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 126
    Par défaut
    OK, merci à vous 2

  5. #5
    Expert éminent
    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
    Billets dans le blog
    1
    Par défaut
    Salut,


    Ta démarche est mauvaise : tu as un problème de performance, et tu tentes d'appliquer une solution sans en avoir déterminé la cause !

    Il faudrait d'abord savoir pourquoi c'est lent.

    Si c'est la lecture en elle-même qui est lente, les threads n'y changeront rien au contraire même car tu auras des accès concurrents supplémentaire, et donc encore plus de blocage I/O...

    Si c'est ton traitement qui est lent, il faut d'abord déterminer la raison de cela, et si tu n'utilises pas un multi-processeur le fait d'utiliser un thread supplémentaire ne va pas améliorer. Il serait alors préférable de revoir l'algo...

    a++

Discussions similaires

  1. Optimisation lecture fichier via un shell script
    Par macleod dans le forum Shell et commandes GNU
    Réponses: 5
    Dernier message: 31/07/2007, 12h46
  2. Réponses: 4
    Dernier message: 09/06/2007, 18h25
  3. optimiser lecture fichier image
    Par cheho dans le forum C++
    Réponses: 17
    Dernier message: 15/09/2006, 14h14
  4. Optimisation lecture d'un fichier en binaire
    Par User dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 13/10/2005, 21h08

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