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

Logging Java Discussion :

Log en couleur pour logiciel de trace, problème de performance


Sujet :

Logging Java

  1. #1
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 3
    Points : 3
    Points
    3
    Par défaut Log en couleur pour logiciel de trace, problème de performance
    Bonjour,
    je développe un logiciel qui log des messages réseaux GSM avec des couleurs différentes pour chaque message.
    Les messages sont lus sur le port série du PC par un handler d'évenements

    le log est dans un panel:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
       private static SimpleAttributeSet log_attribute_set = new SimpleAttributeSet();
        private static Document log_doc;
    
    
    
            panelLog.add(panelLogTitle, BorderLayout.NORTH);
    
            JScrollPane scrollPaneLog = new JScrollPane();
            panelLogDisplay = new JPanel();
            panelLogDisplay.setBackground(Color.WHITE);
            textPaneLog = new JTextPane();
    
            textPaneLog.setEditable(false);
            //textPaneLog.setDoubleBuffered(true);
            textPaneLog.setBackground(Color.WHITE);
            textPaneLog.setFont(CustomFont.getFont("console", 20.0f, Font.PLAIN));
            panelLogDisplay.add(textPaneLog);
            scrollPaneLog.setViewportView(panelLogDisplay);
    
            panelLog.add(scrollPaneLog);
    
            StyleConstants.setForeground(log_attribute_set, cclCustomColors.getColor(textColor));
            StyleConstants.setBackground(log_attribute_set, backGround);
            StyleConstants.setBold(log_attribute_set, bold);    
            StyleConstants.setAlignment(log_attribute_set, alignment);
                    StyleConstants.setFontSize(log_attribute_set, 12);
                    log_doc = textPaneLog.getStyledDocument();
    à chaque message reçu, on le décode, puis on l'affiche avec le code suivant: (text est une String)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        log_doc.insertString(log_doc.getLength(), text, log_attribute_set);
    Ensuite on repositionne le texte:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     MainWindow.textPaneLog.setCaretPosition(log_doc.getLength());
    Problème: l'insertion de la string prend beaucoup de temps CPU. Je le vois avec VisualVM.
    Y aurait il moyen de rendre l'objet Document plus léger?
    Ou carrément d'utilser une autre méthode pour le log, sachant qu'il faut des couleurs différentes?

    Merci

  2. #2
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Points : 7 163
    Points
    7 163
    Par défaut
    Qu'est-ce que tu entends par "beaucoup de temps" ?
    Est-ce vraiment l'insertion du texte qui prend du temps ? Ou plutôt le calcul des paramètres juste avant l'insertion ?
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  3. #3
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Pour faire un log, tu peux également utiliser une JTable, ce qui permet de gérer très facilement la colorisation (voire mettre des icônes par type de log), et qui te permettra accessoirement de gérer facilement des filtres, de supprimer automatiquement les plus anciens logs, etc...

    Pour un autre problème sur le forum, j'ai fait un petit logger au sein de l'exemple fourni ici. Tu y verras notamment comment je gère le scrolling automatique (ou pas, selon qu'on soit en fin de log, ou pas).
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  4. #4
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 3
    Points : 3
    Points
    3
    Par défaut
    Citation Envoyé par dinobogan Voir le message
    Qu'est-ce que tu entends par "beaucoup de temps" ?
    Est-ce vraiment l'insertion du texte qui prend du temps ? Ou plutôt le calcul des paramètres juste avant l'insertion ?
    Non c'est bien l'insertString qui entraîne le pic de CPU

  5. #5
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 3
    Points : 3
    Points
    3
    Par défaut
    Citation Envoyé par joel.drigo Voir le message
    Salut,

    Pour faire un log, tu peux également utiliser une JTable, ce qui permet de gérer très facilement la colorisation (voire mettre des icônes par type de log), et qui te permettra accessoirement de gérer facilement des filtres, de supprimer automatiquement les plus anciens logs, etc...

    Pour un autre problème sur le forum, j'ai fait un petit logger au sein de l'exemple fourni ici. Tu y verras notamment comment je gère le scrolling automatique (ou pas, selon qu'on soit en fin de log, ou pas).
    Euh tu es sûr que ton lien est bon?
    ça parle d'affichage d'un carré...

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

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Citation Envoyé par TontonGrindeur Voir le message
    Non c'est bien l'insertString qui entraîne le pic de CPU
    Concrètement, ça veux dire qu'un insertString consomme combien de ms? et tu fais combien de insertString par seconde? Chaque inserString implique un recalcul de l'affichage, ce qui peut être consommateur. Si tu as beaucoup de ligne à afficher, la suggestion de la JTable me semple plus appropriées, ce sera plus performant, car la JTable ne redessine que la partie visible dans le JScrollPane et ne nécessite pas de tout mettre en forme pour calculer sa taille, si configurée avec un taille de ligne fixe.

Discussions similaires

  1. Alert log oracle pour un Deadlock : trace introuvable
    Par Djam75 dans le forum Administration
    Réponses: 2
    Dernier message: 18/07/2012, 11h38
  2. [AC-2010] Problème de compteur pour logiciel traçabilité
    Par Lukao dans le forum VBA Access
    Réponses: 9
    Dernier message: 26/05/2012, 18h35
  3. [Débutant] Problème avec , au lieu de . pour logiciel
    Par ncheboi dans le forum C#
    Réponses: 1
    Dernier message: 12/07/2011, 20h42
  4. Choix de SGBD et Middleware pour logiciel multi-postes.
    Par Benjamin GAGNEUX dans le forum Bases de données
    Réponses: 8
    Dernier message: 28/09/2004, 12h39
  5. String Grid et choix d'une couleur pour une ligne
    Par Gigottine dans le forum C++Builder
    Réponses: 12
    Dernier message: 17/05/2002, 15h23

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