Optimisation d'un code en java (JTextArea>codage>JTextArea)

Optimisation d'un code en java (JTextArea>codage>JTextArea) - Java - Programmation

Marsh Posté le 20-09-2003 à 20:28:47    

Voila j'ai un JTextArea remplit d'un certain text, il faut que je balaye le JTextArea char par char et remplacer les char par une autre chaine et écrire cette nouvelle chaine dans un autre JTextArea. je fait le tout dans un Thread pour pouvoir moniter l'avancement sur un JProgressBar
 
J'ai testé deux méthodes, je li le char, je cherche le correspondant et je le append dans le JTextArea resultat > ca plante et ca ram :/, deuxieme méthode je cré une String énorme et je fait un setText a la fin > c'est lent mais ca plante plus
 
je cherche a optimisé merci de donner vos avis  :hello:  
 
 
 
voici en gros ce que je fait pour l'instant :
 

Code :
  1. StringReader st = new StringReader(jta_docDepart.getText());
  2.   jta_docCode.setText("" );
  3.   int c;
  4.   String enorme = "";
  5.   c = st.read();
  6.   while(c>=0) {
  7.    enorme = enorme.concat(renvoie_chaine((char)c));
  8.    c = st.read();
  9.    codage++;
  10.   }
  11.   jta_docCode.setText(enorme);
  12.  }


Message édité par sdk le 20-09-2003 à 20:29:21
Reply

Marsh Posté le 20-09-2003 à 20:28:47   

Reply

Marsh Posté le 20-09-2003 à 20:31:50    

StringBuffer

Reply

Marsh Posté le 20-09-2003 à 20:38:00    

Taz a écrit :

StringBuffer


 
effectivement j'aurai du y penser plus tot :/ merci ;)
 
mais now le pb c'est pour afficher un Stringbuffer dans un JTextArea, si je fait un toString setText ca revient au meme :/

Reply

Marsh Posté le 20-09-2003 à 20:39:07    

:heink: concrètement tu fais quoi?

Reply

Marsh Posté le 20-09-2003 à 20:41:07    

Taz a écrit :

:heink: concrètement tu fais quoi?


 
Je code un text en binaire, c'est a dire j'ai ma table de convertion je prend un "a" et je le transforme en "001" (par exemple) et le truc c'est que ca doit etre graphique, donc on doit voir dans un JTextArea une suite de 1 et de 0 correspondant au codage du text d'un autre JTextArea, donc ca fait bcp de  1 et de 0 a afficher :) je cherche donc un moyen maintenant d'afficher mon StringBuffer sans tout faire ramer ...

Reply

Marsh Posté le 20-09-2003 à 20:42:24    

aucun, faut repasser par la casse String

Reply

Marsh Posté le 20-09-2003 à 20:45:20    

Taz a écrit :

aucun, faut repasser par la casse String


 
 :cry:  :cry:  :cry:  
 
 
faut que je trouve le moyen de d'afficher bcp de 0 et de 1 dans un composant sans tout faire ramaÿ  :sweat:  
 
tu penses vraiment qu'il ya pas de solution ?
 
paske le .setText(stringbuffer.toString()) c'est bof :/

Reply

Marsh Posté le 20-09-2003 à 20:47:39    

ça rame à ce point ? quel volume le texte source ?
 
 
edit : tu ferais peut etre bien de tout lire d'un coup, créer le StringBuffer avec la bonne taille initiale d'une part, et pour ta fonction char -> binaire, tu peux soit l'améliorer (avec un String bin[256] pour pas faire 8 tests à chaque fois) ou bien l'inliner à la main pour voir. sinon, je vois rien d'autre : si tu dois traduire tout un texte en un autre, c'est la seule manière il me semble


Message édité par Taz le 20-09-2003 à 21:05:38
Reply

Marsh Posté le 21-09-2003 à 01:11:50    

déjà, utiliser StringBuffer.append() à la place de Strign.concat() ca te fera bcp gagner.
 
ensuite l'autre idée, si tu veux éviter de créer des String inutiles c'est que plutot que ta chaine de codage retourne une String, elle ajoute la chaine à retourner dans un StringBuffer. ex :
String enorme = "";
enorme = enorme.concat(renvoie_chaine((char)c));

devient
StringBuffer enorme = new StringBuffer();
ajoute_chaine((char) c, enorme);

 
à suivre l'arrivée d'un prochain SringBuilder en jdk1.5 (un StringBuffer non synchronizé d'après ce que j'ai compris)


Message édité par benou le 21-09-2003 à 01:12:14

---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le 21-09-2003 à 02:41:20    

euh sur un StringBuffer tu peux faire append(char c) hein ...
 
et pour StringBuilder, j'ai envie de resortir le lien qui explique le fait que la synchronization diminue les perfs est une legende urbaine :D


---------------
Hey toi, tu veux acheter des minifigurines Lego, non ?
Reply

Marsh Posté le 21-09-2003 à 02:41:20   

Reply

Marsh Posté le 21-09-2003 à 10:17:46    

Taz a écrit :

ça rame à ce point ? quel volume le texte source ?
 
 
edit : tu ferais peut etre bien de tout lire d'un coup, créer le StringBuffer avec la bonne taille initiale d'une part, et pour ta fonction char -> binaire, tu peux soit l'améliorer (avec un String bin[256] pour pas faire 8 tests à chaque fois) ou bien l'inliner à la main pour voir. sinon, je vois rien d'autre : si tu dois traduire tout un texte en un autre, c'est la seule manière il me semble  


 
ben en fait ca rame pas au niveau du calcul et de la création du StringBuffer, ca ca marche tres bien, mais quand je veu l'afficher en repassant par un String j'ai un beau "java.lang.OutOfMemoryError" :/, sur un test d'uun fichier d'un mo.
 
j'ai pas bien comprit ton histoire de String bin[256]  :(

Reply

Marsh Posté le 21-09-2003 à 10:18:42    

benou a écrit :

déjà, utiliser StringBuffer.append() à la place de Strign.concat() ca te fera bcp gagner.
 
ensuite l'autre idée, si tu veux éviter de créer des String inutiles c'est que plutot que ta chaine de codage retourne une String, elle ajoute la chaine à retourner dans un StringBuffer. ex :
String enorme = "";
enorme = enorme.concat(renvoie_chaine((char)c));

devient
StringBuffer enorme = new StringBuffer();
ajoute_chaine((char) c, enorme);

 
à suivre l'arrivée d'un prochain SringBuilder en jdk1.5 (un StringBuffer non synchronizé d'après ce que j'ai compris)


 
oui avec le stringbuffer ca marche tres bien, j'append a chaque passage et c'est tres rapide, maintenant le probleme se pose pour l'affichage :/ car je doit repasser par un string et donc on revient au pb de départ :/

Reply

Marsh Posté le 21-09-2003 à 10:32:20    

Sdk a écrit :


 
ben en fait ca rame pas au niveau du calcul et de la création du StringBuffer, ca ca marche tres bien, mais quand je veu l'afficher en repassant par un String j'ai un beau "java.lang.OutOfMemoryError" :/, sur un test d'uun fichier d'un mo.


 
c'est que tu fais péter la limite des 64Mo si je ne m'abuse
essaye
-Xmx96m
 
tu ferais bien de profiler tout ça quand même pour être sur de savoir ou sont les problèmes. elle fais quelle taille ta String finale ? moi je te conseille de tout lire d'un coup déjà, à savoir n char, ensuite new StringBuffer(n), remplissage [appel au gc], toString
 

Sdk a écrit :


j'ai pas bien comprit ton histoire de String bin[256]  :(  


 
ben
 
String bin[256]={
 "00000000"
 "00000001"
 ....
 "11111111"}
 
passe en hexa  :sol:

Reply

Marsh Posté le 21-09-2003 à 10:58:35    

Taz a écrit :


 
c'est que tu fais péter la limite des 64Mo si je ne m'abuse
essaye
-Xmx96m
 
tu ferais bien de profiler tout ça quand même pour être sur de savoir ou sont les problèmes. elle fais quelle taille ta String finale ? moi je te conseille de tout lire d'un coup déjà, à savoir n char, ensuite new StringBuffer(n), remplissage [appel au gc], toString
 
ben
 
String bin[256]={
 "00000000"
 "00000001"
 ....
 "11111111"}
 
passe en hexa  :sol:  


 
je comprend pas tout  :pt1cable: , bref le principe de base c'est de simuler la compression d'un fichier text, c'est a dire ouvrir le fichier dans un jtextarea, ensuite calculer le code correspondant a chaque char ( les trucs de bases de compressions, on calcul les effectifs ) donc en fait mon code obtenu est un code a longeur variable, et il est préfix pour que je puisse décoder.
 
le principe c'est donc ouvrir un fichier(jtextarea) > trouver le code > afficher le fichier codé en binaire (jtextarea) > décoder > afficher le text identique a l'original.
 
le probleme vient bien quand je fait le tostring de mon sb, car j'ai un jprogressbar qui monitore, et en fait a 100% ca commence a ramer... et out of mémory, sur des petits fichiers ca marche tres bien, mais des que le fichier est un peu gros, le calul du sb marche toujours bien mais au toString ca merde :/
 
 
edit : un screenshot pr mieu visualiser : http://membres.lycos.fr/pok3s/jcode.jpg


Message édité par sdk le 21-09-2003 à 11:02:58
Reply

Marsh Posté le 21-09-2003 à 10:58:42    

Sdk a écrit :


oui avec le stringbuffer ca marche tres bien, j'append a chaque passage et c'est tres rapide, maintenant le probleme se pose pour l'affichage :/ car je doit repasser par un string et donc on revient au pb de départ :/


mais non le problème est pas le même !!!!
Une fois que ton StringBuffer est rempli, tu le passes en String et c'est bon.
 
Le problème avec ton ancienne manip c'est qu'à chaque fois que tu faisait un concat,  ca créé une nouvelle String => si ta boucle c'était sur un fihcier d'1Mi, tu crées une String de ., 6, 9, 12, ..., 2 999 997, 3 000 000 octet. Bref, tu faisais exploser la mémoire : ton prog consommais 4,5 Téra octets de mémoire !!!! tu métonnes qu'il faisait un OutofMemory ! :/
 
Le truc à faire : créer un StringBuffer de la bonne taille (tu peux l'estimer sir tu connais la taille du fichier). Ca évitera les copies inutiles pour l'agrandir. A la fin tu auras un StringBufferqui prendra environ 3Mo. tu fais un toString pour le récupérer sous forme de String => ca créé un 2e objet de 3Mo. C'est gourmand en rame mais on reste dans les limites du raisonable.
 
Par contre, quand tu vas voiloir afficher ca (le mettre dans ton JTextField), Swing y risque de pas être content : afficher 6 millions de caractère, il risque d'avoir du mal à digérer :/
 
Mais bon, c'est pas le passage du StringBuffer à String qui va poser problème


---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le 21-09-2003 à 11:02:44    

cela dit pour ta compression en elle meme, j'espere que tu travailles pas avec des char mais bien avec des byte et des opéations binaires

Reply

Marsh Posté le 21-09-2003 à 11:04:24    

the real moins moins a écrit :

euh sur un StringBuffer tu peux faire append(char c) hein ...


sans blague :o
 
mais ca évite de créer des chaines inutiles de directement l'ajouter au StringBuffer
 

the real moins moins a écrit :


et pour StringBuilder, j'ai envie de resortir le lien qui explique le fait que la synchronization diminue les perfs est une legende urbaine :D


 
ben tiens ... et la gestion des sections critiques, etc ... faut bien qu'elle les execute quand même la JVM :o
Dire que c'est pas aussi gourmand que la "légende" le raconte OK, mais y a forcément un coût [:spamafote]
 
Dans le cas d'utilisation poussée du StringBuffer en monothreadé, ils prévoient une amélioration de 20% des perfs avec le StringBuilder ...


---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le 21-09-2003 à 11:04:47    

Taz a écrit :

cela dit pour ta compression en elle meme, j'espere que tu travailles pas avec des char mais bien avec des byte et des opéations binaires


méga +1  [:wam]


---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le 21-09-2003 à 11:10:07    

Taz a écrit :

cela dit pour ta compression en elle meme, j'espere que tu travailles pas avec des char mais bien avec des byte et des opéations binaires


 
bah j'essaie mais pour opéations binaires j'ai du mal :/
 
edit : on gagne vraiment ?


Message édité par sdk le 21-09-2003 à 11:10:39
Reply

Marsh Posté le 21-09-2003 à 11:12:06    

Sdk a écrit :


edit : on gagne vraiment ?


un ton avis ?
utiliser 1 bit à la place de 8 ca risque d'améliorer les perfs ? :/


---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le 21-09-2003 à 11:15:12    

benou a écrit :


un ton avis ?
utiliser 1 bit à la place de 8 ca risque d'améliorer les perfs ? :/


 
effectivment   :)

Reply

Marsh Posté le 21-09-2003 à 11:22:24    

benou a écrit :


un ton avis ?
utiliser 1 bit à la place de 8 ca risque d'améliorer les perfs ? :/


 
ouais mais avec des bytes je pert de la présition pour les char spéciaux ? y me reconnai pas tout en byte

Reply

Marsh Posté le 21-09-2003 à 11:24:40    

ben non. tes données son sous une forme données (char[], String, etc), toi tu convertis tout ça en byte et bosse dessus), ou alors lecture directe sous forme de byte

Reply

Marsh Posté le 21-09-2003 à 11:28:45    

Taz a écrit :

ben non. tes données son sous une forme données (char[], String, etc), toi tu convertis tout ça en byte et bosse dessus), ou alors lecture directe sous forme de byte


 
heu mais par exemple un 'é' jeu pas le coder avec un byte :/


Message édité par sdk le 21-09-2003 à 11:30:53
Reply

Marsh Posté le 21-09-2003 à 11:34:50    

:heink:

Reply

Marsh Posté le 21-09-2003 à 11:35:08    


 
 :(
 
explain to me  :sweat:
 
ben je sais avec un byte je peu coder que la table ascii et ca reste limité quand meme ... ou bien j'ai vraiment rien capté  :whistle:


Message édité par sdk le 21-09-2003 à 11:48:46
Reply

Marsh Posté le 21-09-2003 à 11:51:14    


 
allé un peut de compassion  :cry:


Message édité par sdk le 21-09-2003 à 11:52:35
Reply

Marsh Posté le 21-09-2003 à 11:53:14    

bah regarde java.lang.Byte quand même

Reply

Marsh Posté le 21-09-2003 à 11:57:42    

sinon affiche de l'hexa et ton problème de perf va s'arranger, et ça n'en sera que plus lisible


Message édité par Taz le 21-09-2003 à 11:57:54
Reply

Marsh Posté le 21-09-2003 à 12:09:27    

Taz a écrit :

bah regarde java.lang.Byte quand même


 
j'ai regardé, et je lit un peu les trucs de codages de la doc java,
 
mais en fait vous me conseillé au lieu de travailler avec un "char" pour un caratere de travailler avec un "byte" par caracter c'est ca ?
 
j'ai bien comprit que le but est d'évité de travailler avec des char codé sur 1octet, mais je comprend pas bien comment faire :/


Message édité par sdk le 21-09-2003 à 12:10:24
Reply

Marsh Posté le 21-09-2003 à 12:10:34    

ben les bytes, c'est fait pour représenter du binaire

Reply

Marsh Posté le 21-09-2003 à 12:16:46    

Taz a écrit :

ben les bytes, c'est fait pour représenter du binaire


 
je comprend pas bien comment coder un char dans un byte [:almar]

Reply

Marsh Posté le 21-09-2003 à 12:20:57    

j'abandonne

Reply

Marsh Posté le 21-09-2003 à 12:22:57    

Taz a écrit :

j'abandonne


 
naaaaaaaaaan  :cry:

Reply

Marsh Posté le 21-09-2003 à 12:38:27    

hann, je viens de réveillé, croyait que vous étiez entrain de me parler pour l'affichage, rololo 30min que je me prend la tete a essayé de comprendre ce que vous voulez lol, évidement que mon fichier compressé je l'écrit en binaire, c'est pas une fichier texte avec des 0 et des 1 dedans, c'est bien ce ca ques vous aviez peur non ?, là je bosse avec des char etc car tout doit etre graphic, mais le fichier en lui meme est évidement écrit en binaire

Reply

Marsh Posté le 21-09-2003 à 13:14:48    

et donc pout mettre un gros StringBuffer avec un composant swing quelqu'un a une id ?

Reply

Marsh Posté le 21-09-2003 à 13:15:08    

benou a écrit :


sans blague :o
 
mais ca évite de créer des chaines inutiles de directement l'ajouter au StringBuffer
 

ben oui, pourquoi tu dis "mais" !?
dans ton example de code, tu passais justement par une methode intermediaie pour ajouter le char...
 
bref...
 


---------------
Hey toi, tu veux acheter des minifigurines Lego, non ?
Reply

Marsh Posté le 21-09-2003 à 13:35:22    

Sdk a écrit :

et donc pout mettre un gros StringBuffer avec un composant swing quelqu'un a une id ?


 
 
bref ... comment j'afficher mon gros StringBefouz  :whistle:

Reply

Marsh Posté le 21-09-2003 à 14:21:36    

the real moins moins a écrit :

ben oui, pourquoi tu dis "mais" !?
dans ton example de code, tu passais justement par une methode intermediaie pour ajouter le char...


je pense que t'as pas capté : le char il le transforme en String => si tu ajoute directement les différent char de la String dans le buffer c'est plus rapide que de créer une String puis de l'ajouter dans le buffer.


---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le 21-09-2003 à 14:22:15    

Sdk a écrit :

et donc pout mettre un gros StringBuffer avec un composant swing quelqu'un a une id ?


à quoi ca va te servir d'avoir un textfield avec des millions de caractères dedans ? c'est illisble !!  
c'est quoi l'intéret d'afficher ca ?


---------------
ma vie, mon oeuvre - HomePlayer
Reply

Marsh Posté le    

Reply

Sujets relatifs:

Leave a Replay

Make sure you enter the(*)required information where indicate.HTML code is not allowed