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

Langage Java Discussion :

Programme java long à démarrer parfois


Sujet :

Langage Java

  1. #1
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut Programme java long à démarrer parfois
    Bonjour,
    J'aimerais comprendre qu'est ce qui se passe avant le lancement d'un programme java. J'ai une application java encapsuler dans un exe avec launch4j et le chargement de l'application est super long parfois (4-5 minutes ) sans que rien de visuel ne ce passe or j'affiche un splashscreen dès le début de mon programme.

    Donc ma question est qu'est ce qui ce passe pour que ce soit aussi long et comment je peux faire pour améliorer ce temps de chargement.

    Merci.

  2. #2
    Membre Expert Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 704
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 704
    Par défaut
    Le démarrage d'un prog Java prend un peu de temps car il faut charger les classes et les vérifier avant de commencer l'exectution. Donc ça prend un petit temps incompressible pendant lequel une fenêtre n'est pas affichée.
    Pour palier à ce problème depuis java 6, on peut spécifier une image splashscreen dans le jar qui sera affichée pendant ce temps de chargement. on pourra y accéder ensuite via la classe java.awt.SplashScreen dès qu'elle sera chargé, si par exemple tu veux y ajouter une barre de progression pendant le chargement d'autre ressources.

    Ceci dit avec les progrès des JVM ce temps devrait être au pire de quelque secondes. 4-5 minutes c'est énorme, je serais bien curieux de savoir ce que ton programme peut bien faire pour être aussi long a démarrer. Il nous faudrait plus de détail sur ton programme pour comprendre ce qui le rend si long.

  3. #3
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    Merci pour ta réponse mais comment je peux faire pour savoir ce qui ce passe en amont de mon programme, mon splashscreen (que j'ai modifié depuis) s'ouvrait dès le début du main donc il n'y a aucun code avant et pourtant au premier lancement cela prend énormément de temps avant de voir apparaitre le splahscreen (qui n'etait même pas une image mais une jFrame avec un jLabel). Y a t il un moyen pour "tracer" ce qui ce passe en amont ?
    Merci

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    1 252
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 252
    Par défaut
    Rajoute ceci dans ton fichier Manifest (ou édite-le pour qu'il ressemble à ceci) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
         Manifest-Version: 1.0
         Main-Class: SplashTest
         SplashScreen-Image: splash.gif
    Une fois cela fait, regarde ce qui prend le plus de temps : avant l'affichage du splash-screen ou entre le splash-screen et les premières instructions exécutées...

  5. #5
    Membre Expert Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 704
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 704
    Par défaut
    un temps de démarrage aussi long me parait vraiment louche. Est ce aussi long quand tu exécutes ton jar via "java -jar monJar.jar" que via launch4j?

  6. #6
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    j'ai fait deux tests en utilisant un splashscreen :
    un premier dans launch4j dans ce cas j'ai direct le splashscreen et l'appli démarre après un long moment et

    un deuxième en spécifiant le splashscreen dans le manifest et dans ce cas j'ai le splashscreen quelques secondes avant l'ouverture de l'appli mais il ne se passe rien pendant un long moment.

    Je précise que cela n'est pas récurrent à chaque démarrage mais systématique au démarrage de la machine et quelque fois après un redémarrage de l'application.

    Bon moi aussi ça me parait bizarre mais je ne sais pas trop comment résoudre ce problème. est-ce que cela pourrait venir du chargement de jar externe ?

  7. #7
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 483
    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 483
    Par défaut
    Citation Envoyé par smith_dev Voir le message
    J'ai une application java encapsuler dans un exe avec launch4j et le chargement de l'application est super long parfois
    Est-ce que launch4j ne passerais pas 4-5 minute à décompacter la jvm incluse dans un dossier temporaire avant de la lancer, ça expliquerais. La question est donc: ton appli est-elle aussi lente à démarrer quand tu n'utilise pas launch4j ?

  8. #8
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    Merci de ton aide tchize_.

    J'ai fait le test suivant, j'ai redémarré le pc.
    J'ai lancé un java -jar monappli sur mon jar.
    Et là il se passe 1 minute 20 secondes avant que le splashscreen s'affiche (inclu dans le manifest).

    Bon quand je disais 4-5 minutes c parce que ça me paraissait super long mais 1 min 20 c aussi très long surtout sans aucune activité !!

    Au deuxième démarrage le splashscreen s'affiche immédiatement et l'appli démarre au bout de quelques secondes (3-4).

  9. #9
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 483
    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 483
    Par défaut
    1 minute 20 puis 3-4 secondes?? La seule chose que je vois qui réduirait le temps lors du deuxième démarrage, ce serait le fait que les fichiers soient dans le cache disque et que tu n'aie plus besoin d'attendre tes disque durs.... Or une telle différence voudrait dire des disques dur très lent. Tu met combien de temps, après un démarrage, pour copier le répertoire de la jvm vers un autre répertoire? Se pourrait-il que ce soient tes disques qui ralentissent tout??? Si tu ouvre une console et que tu tappe "java -version", ca met combien de temps à répondre?

  10. #10
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    Je viens de faire le test du java -version après un redémarrage de la machine, ça dure à peu près 1 minute aussi et suite à ça mon programme se lance en 4 -5 secondes ??
    j'y comprend pas grand chose.

    Le repertoire de la jvm si c'est bien ça j'ai copier le contenu du repertoire java et ça ne met pas plus de temps que ça (10 secondes pt).

    Voilà d'autre piste à me proposer ?

  11. #11
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 483
    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 483
    Par défaut
    c'est curieux, mais une application qui démarre en 2 minutes puis qui met seulement 2 secondes les fois suivantes, je mettrais ca sur le dos de l'os ou du matériel qui est occupé de lacher.... t'as pas le meme problèmes avec d'autres grosses applications? Et qu'en est-il de la mémoire vive, se pourrait-il qu'elle soit une peu encombrée et que tu commence par perdre du temps à faire de la place par swapping avant de pouvoir mapper en mémoire le process java?

  12. #12
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    En fait quelque soit l'application que je lance le premier démarrage est super long (j'ai fait le test en lançant launch4j) :lancement de la jvm je suppose, il faudrait que je trouve un moyen d'attendre que la jvm soit lancée pour lancé mon prog sinon le splashscreen s'affiche plus d'une minute c'est moyen ! et ensuite je dois maintenir la jvm en service enfin là c'est une supposition mais cela se produit après une mise à jour de mon prog ou je l'arrete puis je le relance (mais par l'installation), je suppose donc que la jvm s'arrete puis se relance non ? c'est possible ça ? comment je peux voir si la jvm est en route ou non ?

    En ce qui concerne les machines c'est possible que cela vienne de là en tout cas le temps d'attente n'est pas du tout le même en fonction des machines.

    Merci en tout cas pour ces informations

  13. #13
    Invité
    Invité(e)
    Par défaut
    Salut,
    Si j'ai bien compris ce que tu viens de dire : Il n'y a pas une unique instance de la JVM sur ton ordi qui se lance. Il y en a une par programme java lancé. A chaque fois que tu lances ton programme, une nouvelle instance de la JVM est créée pour ce programme avec son propre environnement.
    Pour moi (comme pour tchize_) ca doit venir de l'OS ou de la machine. Une question comme ca : c'est des machines avec tout en local ou les applis sont installées sur des partitions distantes ?

  14. #14
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    non tout est en local, merci pour ton explication mais je trouve ça bizarre ou du moins la parade que j'ai trouvé ne colle pas avec ton explication :

    Au démarrage du pc je lance une appli java qui doit en fin de traitement lancer mon programme, (du coup le sphascreen s'affiche que quelque secondes) puisque la jvm est déjà lancée ?
    Lorsque je fais des mises à jours de mon programme je passe par le même procédé du coup il y a toujours un programme java de lancé et impeccable tout démarre nikel moyennant les 4 - 5 secondes de mise en route de mon programme.

    Du coup je considère que le problème est résolu mais je veux bien plus d'informations si vous en avez.

  15. #15
    Membre Expert Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 704
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 704
    Par défaut
    Une application (java ou non) prend en général quelque secondes de plus au premier lancement qu'aux suivants grace aux systèmes de cache, mais ton cas me parait particulièrement extrême. Es-tu sur que tu ne le lance pas sur une machine vraiment trop faible, ou surchargé de logiciel pompant la mémoire?
    Essaye sur une autre machine pour voir. A mon avis le problème ne viens pas de java mais de ta machine.

  16. #16
    Membre averti
    Inscrit en
    Janvier 2008
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 21
    Par défaut
    Oui je le pense aussi car le comportement est bien différent suivant les machines mais mon astuce m'a permis d'obtenir un temps d'exécution qui me satisfait donc c'est bon.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Démarrer la programmation java sur un Mac OSX
    Par cyriak dans le forum Développement OS X
    Réponses: 1
    Dernier message: 25/09/2013, 15h09
  2. [Avis] Les meilleurs programmes Java ?
    Par christopheJ dans le forum ImageJ
    Réponses: 69
    Dernier message: 07/10/2008, 02h12
  3. Comment démarrer la programmation JAVA / WEB ?
    Par belocom dans le forum Développement Web en Java
    Réponses: 2
    Dernier message: 04/01/2008, 16h20
  4. [votre avis m'interesse] Interface avec un programme Java
    Par LineLe dans le forum Interfaces Graphiques en Java
    Réponses: 29
    Dernier message: 11/12/2004, 12h39
  5. Lancement d'un programme java depuis un script php
    Par gexti dans le forum Développement Web en Java
    Réponses: 8
    Dernier message: 07/05/2004, 18h40

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