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 :

Parallelisation de code


Sujet :

Java

  1. #1
    Membre éclairé
    Inscrit en
    Janvier 2005
    Messages
    491
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 491
    Par défaut Parallelisation de code
    Hello,
    J'essai de paralléliser une partie de mon application. A la base, j'importe des objets à partir d'un fichier dans une base de données. Comme je suis suceptible d'en importer plusieurs millions, je souhaite paralléliser mon import.

    J'ai un problème lorsque je crée mon objet java à partir de sa représentation dans le fichier. Une exception est levée, mais je ne la maitrise pas car elle se situe dans le code d'une librairie jar externe, qui n'est donc à prioris pas thread safe.

    Vioci le code du constructeur ainsi que l'endroit exacte où l'exception (ArrayOutOfBounds) est levée:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    public MyObject (String rep)
        {
            super(rep) ;
            InputStream is = new ByteArrayInputStream(rep.getBytes("UTF-8")) ;
     
            SimpleReader sr = new SimpleReader(is, sdfType) ;
            sr.readNext(this.o) ; // Exception
            sr.close();
        }
    Sachant que je ne maitrise pas le code qui lève l'exception, y'a t-il un moyen de contourner ce genre problème ?

    Merci d'avance!

  2. #2
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Citation Envoyé par vinzzzz Voir le message

    Sachant que je ne maitrise pas le code qui lève l'exception, y'a t-il un moyen de contourner ce genre problème ?

    Merci d'avance!
    Tu veux dire que tu ne maitrise pas le MyObject? A priori, cette exception est levée car tu fournis en paramètre un String qui ne correspond pas à ce à quoi il s'attends. Sinon, un try catch autour de l'appel à new MyObject() suffirais à gérer l'exception.

  3. #3
    Membre émérite Avatar de Jidefix
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    742
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Septembre 2006
    Messages : 742
    Par défaut
    Je pense qu'il parle plutôt de la classe SimpleReader.
    Le problème c'est que nous n'avons pas non plus le code ou même la documentation de cette classe, donc impossible de dire pourquoi ça plante. Moi je vote pour un problème de sérialisation/desserialisation (ça se dit?)

    Qu'est ce qui te fait penser que ton erreur est liée à la synchronisation? Ca marche quand tu lances ton appli une fois mais plante quand tu la lances plein de fois en même temps c'est ça?

  4. #4
    Membre éclairé
    Inscrit en
    Janvier 2005
    Messages
    491
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 491
    Par défaut
    Oui c'est bien ca: ca marche en une fois, mais dés que plusieurs thread sont lancés, ca plante. Ca n'est même pas dans la classe SimpleReader que ca plante: c'est dans d'autrs classes appelées par la méthode readNext.

    Ca devient compliqué de paralléliser des traitements lorsqu'on utilise des librairies tierces n'ayant pas été pensé pour l'être...

  5. #5
    Membre émérite Avatar de Jidefix
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    742
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Septembre 2006
    Messages : 742
    Par défaut
    C'est pour ça qu'on a crée les blocs "synchronized"

    Juste une intuition: sdfType, ce serait pas un objet SimpleDateFormat par hasard?
    Si c'est le cas c'est la cause de ton problème: les classes XXXXXFormat de l'API java utilisent des buffers internes qui font que même pour un simple parse() ou format() on risque des problèmes d'accès concurrents.
    Donc: il ne vaut mieux pas partager ce genre d'objet.

  6. #6
    Membre éclairé
    Inscrit en
    Janvier 2005
    Messages
    491
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 491
    Par défaut
    Nope c'est un objet spécifique et ca n'est pas lui la cause

    Je vais donc y aller a coup de synchronized..

Discussions similaires

  1. De la rapidité du code
    Par jfloviou dans le forum Contribuez
    Réponses: 233
    Dernier message: 29/05/2009, 02h17
  2. code pour interbase 6.0 et 6.5 de generateur
    Par tripper.dim dans le forum InterBase
    Réponses: 4
    Dernier message: 01/07/2002, 11h29
  3. [MFC](encapsulation ADO) ou placer le code
    Par philippe V dans le forum MFC
    Réponses: 2
    Dernier message: 13/06/2002, 14h58
  4. Explorateur de code C
    Par Zero dans le forum C
    Réponses: 14
    Dernier message: 06/06/2002, 09h41
  5. OmniORB : code sous Windows et Linux
    Par debug dans le forum CORBA
    Réponses: 2
    Dernier message: 30/04/2002, 17h45

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