Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : exécutable jar plus lent que eclipse [ Divers / Général ] (yyyx)

vendredi 4 juillet 2008 à 10:45:43 | exécutable jar plus lent que eclipse

yyyx

Bonjour à tous !

Je viens de créer une petite application java qui, à partir d'un fichier xls me renvoie les données dans un csv et les en-têtes de colonnes ansi que diverses informations dans un fixhier xml.
Evidemment, je suis obligé d'utiliser une librairie. J'ai choisi poi.

Jusque là, tout va bien, mon appli fonctionne à merveille :D

J'ai donc buildé le tout, d'abord avec fat-jar (un module d'éclipse permettant d'inclure toutes les librairies dans l'exécutable). Mais ohh surprise, le temps d'éxécution qui dans éclipse était d'environ 7sec pour un fichier d'à peu près 1000 lignes * 250 colonnes passe à 30 secondes !

Je me suis alors dit, plugin de merde, retour au bon vieux classpath et la librairie dans le dossier lib. Re-surprise, il me faut alors 40 secondes pour extraire les données du même fichier !

Bon, je sais, mon algo n'est surement pas tip-top (je parcours les cellules par lignes et concatène les données dans un string) mais si je pouvais éviter de tripler le temps d'éxécution en créant un exécutable, ça m'arrangerais. Avez-vous une idée d'où vient le pb ??

Merci d'avance.

Laurent

vendredi 4 juillet 2008 à 13:04:18 | Re : exécutable jar plus lent que eclipse

tlaloctzin

Membre Club

Coucou , t as essayé de compiler ton jar avec des arguments du type -Xms512m ?

Il vaut mieu être riche et en bonne santé que pauvre et malade .

vendredi 4 juillet 2008 à 14:37:10 | Re : exécutable jar plus lent que eclipse

yyyx

Non, je n'avais pas essayé, je viens donc de le faire et ça ne change rien :
java -Xmx512m -Xms32m -jar xls2csv.jar test.xls test.csv test.xml 35 sec

Après un petit tour sur google, il s'avère que ces arguments servent à augmenter la mémoire allouable quand un objet dépasse la taille maximum.

Or ce n'est pas mon cas. Ici, je n'ai pas d'erreur, juste une forte augmentation du temps d'éxécution.

Après optimisation, j'ai réussi à réduire un peu le nombre de boucles : je gagne 1 sec en exécution dans éclipse et 6 avec le jar !

Si quelqu'un sait comment récupérer les paramètres d'exécution dans eclipse pour lancer le jar de la même façon dans le terminal je suis prenneur. En attendant, je googlise :D

Bonne aprèm à tous



vendredi 4 juillet 2008 à 16:18:18 | Re : exécutable jar plus lent que eclipse

AlexN

Il vaut mieux concaténer tes chaines de caractères avec un StringBuffer ou un StringBuilder, plutôt que de faire String = new String() + new String() + new String(); Parce qu'à chaque new String() il y a création d'un nouvel objet.

vendredi 4 juillet 2008 à 17:49:07 | Re : exécutable jar plus lent que eclipse

yyyx

Merci du tuyau :D

Mais même si cela me permet de gagner encore tu temps d'exécution, ça ne résoud toujours pas mon pb de différence d'exécution entre eclipse et le terminal...

vendredi 4 juillet 2008 à 18:20:10 | Re : exécutable jar plus lent que eclipse

AlexN

J'ai dit ça parce que sinon je n'ai aucune idée sur ton problème. Mais il m'intéresse, c'est au cas où quelqu'un trouve une solution.
y'aurait une option du genre "java -runAtSpeedOfLight -jar my.jar" ?

vendredi 4 juillet 2008 à 18:32:16 | Re : exécutable jar plus lent que eclipse

yyyx

MDR
Ce serait bon ça

Mais bon, je pense que eclipse doit gérer par lui même des options lors du run, quelquechose qui optimiserait l'allocation de la mémoire ou un truc comme ça, j'en sais pas grand chose, tout ce que je constate c'est que dès que je lance mon appli via le terminal, il faut 5 fois plus de temps...
Et comme je débute en java et sous eclipse, ben je trouve pas où c'est...

Surtout qu'apparemment, mon appli est destinée à servir sur un projet de gestion de données où on doit pouvoir importer un dataset en xls de taille assez conséquente, le tout sur, me semble-t-il, un vieux serveur pourri. Donc si la version jar du truc met 40 secondes sur 1 P4 2GHz/1GoDDR pour un fichier de seulement 1000valeurs*250variables=250000 cellules, et pas 2000variables*10000valeurs, ça va pas le faire.

Merci quend même de t'intéresser à mon cas, je testerai le coup du StringBuffer dès lundi.

lundi 7 juillet 2008 à 09:55:02 | Re : exécutable jar plus lent que eclipse

yyyx

Personne n'a d'idée sur mon pb ??

Je viens de tout passer en String Buffer, tu avais raison, 2 secondes à l'exécution dans éclipse. Je suis plutôt satisfait.

Mais une fois compilé et exporté en jar, il m'en faut 25 ...

lundi 7 juillet 2008 à 10:12:23 | Re : exécutable jar plus lent que eclipse

AlexN

Attention pour vraiment gagner du temps, il faut choisir la bonne classe :

- environnement multithread où il est nécessaire de synchroniser l'accès aux données : StringBuffer
- environnement où il n'y a pas besoin de synchroniser les accès : StringBuilder

Le second choix est plus rapide mais ne fonctionnera pas en environnement synchronisé.

lundi 7 juillet 2008 à 10:26:16 | Re : exécutable jar plus lent que eclipse

yyyx

Je n'ai pas besoin de travailler en multithread.
Je ss donc passé au StringBuilder, ça ne change pas grand chose mais si c'est théoriquement plus rapide, je garde.
Avec tout ça, merci j'ai pu gagner pas mal de temps d'exécution dans eclipse (et apprendre pas mal de nouveaux trucs).
Mais je cherche toujours quelquechose pour en gagner à l'extérieur, parce que passer de 1.5 secondes dans éclipse à 20 dans le terminal, ça m'ennuie un peu, mais bon, si on peut pas faire autrement, je m'en passerai.


1 2

Cette discussion est classé dans : fichier, données, lent, jar, exécutable


Répondre à ce message

Sujets en rapport avec ce message

SOS URGENT, Problème lors de la création d'un jar exécutable [ par FunkyJulius ] Tout d'abord bonjour, Voilà, j'ai créer une petite applic, un jeu de Black Jack. Quand je l'éxécute sous eclipse, pas de problème, tout ce passe com Utiliser des images ou fichier txt avec un jar exécutable [ par bourgi220 ] Bonjour, Je me suis déjà beaucoup documenté sur les jar exécutables, j'ai notamment lu ce sujet: http://www.javafr.com/infomsg_CR-233-ER-FICHIER-JAR-E Problème de Connexion MS Access et Java [ par eclisia ] Bonjour,</fon ouvrir un .jar depuis eclipse [ par celinet17 ] Bonjour,Voila j ai un fichier.jar qui fonctionne.J ai crée un projet java sous eclipse. Lorsque je compile mon projet, un menu s affiche et je voudrai extraire fichier d'un jar [ par didoux95 ] Bonjour à tous.j'aimerais savoir si il est possible d'extraire, d'un JAR, les fichiers désirés; et ce depuis le même JAR (==> un jar qui extrait ses p fichier jar [ par Tunis_khalifa ] j ai un code sourceest ce que je peut creer son fichier jar?Si oui comment?et merci d'avance Sauvegarde des données saisies dans une interface web dans un fichier XML [ par mimomama ] Salut tout le monde et spécialement pour ceux qui lisent ce message.   Mon probléme consiste à sauvegarder des données saisies dans une interface web XMl(RSS) [ par mimosa803 ] Bonsoir, j'ai un problème pour générer un fichier RSS à partir d'un fichier XML .J'utilise Jdom comme parseur XML pour manipuler le document XML . Bon


Nos sponsors

Sondage...

CalendriCode

Novembre 2008
LMMJVSD
     12
3456789
10111213141516
17181920212223
24252627282930

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,234 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.