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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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 690
    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 690
    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 690
    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 690
    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 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 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 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
    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 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
    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?

+ 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, 14h09
  2. [Avis] Les meilleurs programmes Java ?
    Par christopheJ dans le forum ImageJ
    Réponses: 69
    Dernier message: 07/10/2008, 01h12
  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, 15h20
  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, 11h39
  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, 17h40

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