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

avec Java Discussion :

Code anormalement lent


Sujet :

avec Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 24
    Points : 19
    Points
    19
    Par défaut Code anormalement lent
    Bonjour à tous

    j'ai un code qui est bizarement lent le voici :
    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
    28
    29
    30
    31
    32
    33
    34
    35
     
        private int compare(int delay)
        {
            int count = 0;
     
            //faire une copie de dc2_copy
            ArrayList<decompose> dc2_copy3 = new ArrayList<decompose>();
            for (int k = 0; k < dc2_copy.size(); k++)
            {
                dc2_copy3.add(new decompose());
                dc2_copy3.get(k).start = dc2_copy.get(k).start;
            }
            //on compare dc2_copy3 et dc1
            int s1 = dc1.size();
            for (int i = 0; i < s1; i++)
            {
                double b = dc1.get(i).start;
                int s2 = dc2_copy3.size();
                double a=0;
                for (int j = 0; j < s2; j++)
                {
                    //le fait de laisser la ligne suivante seule augmente considérablement le temps de calculs
                    a = dc2_copy3.get(j).start;
     
                    if (a > b - delay && a <= b + delay)
                    {
                        count++;
                        dc2_copy3.get(j).start = -1999999999;
                        j = dc2_copy3.size(); //break
                    }
                }
            }
     
            return count;
        }
    ce qui est étrange c'est que si je supprime la ligne suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    a = dc2_copy3.get(j).start;
    j'ai une exécution quasi instantannée.

    la question est pourquoi ? et qu'est-ce que je fais de travers?

    merci!

    je rajoute la classe "décompose" pour que vous sachiez tout:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    public class decompose {
        public int number;
        public double start;
        public double end;
        public String text = "";
        public String timecodes = "";
    }

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 24
    Points : 19
    Points
    19
    Par défaut
    en fait j'en suis arrivé à la conclusion que l'utilisation d'arraylists ralenti considérablement le code

    voici un code assez simple

    la première partie est instantannée. et la seconde prends au moins 40 seconde à s'exécuter

    pourtant elles font le même nombre de calculs

    je ne comprends pas. !

    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
     
            double[] dc2_copy = new double[1000000];
            for (int k = 0; k < 1000000; k++)
            {
                dc2_copy[k] = k;
            }
     
            for (int i = 0; i <  1000000; i++)
            {
                for (int j = 0; j < 10000; j++)
                {
                     double a = dc2_copy[j];
                }
            }
     
            JOptionPane.showMessageDialog(frame, "1");
    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
            List<Double> number = new ArrayList<Double>();
            for (int k = 0; k < 1000000; k++)
            {
                number.add((double)k);
            }
     
            for (int i = 0; i < 1000000; i++)
            {
                for (int j = 0; j < 10000; j++)
                {
                    double a = number.get(j);
                }
            }
     
            JOptionPane.showMessageDialog(frame, "2");
    quelqu'un pourrait-il m'aider?

    merci!

  3. #3
    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
    Les list servent à stocker des ensemble de données de taille variable. Dans ton cas, il est donc inutile car la taille de dc2_copy3 est connue à l'avance. En plus, ça n'a aucun sens de consommer plein de mémoire avec des "Decompse" car tu ne fais que stocker un double par entrée et ignorer les autres champs.
    De plus, une arraylist qui grandit implique à chaque agrandissement de son stockage interne une copie du tableau. La capacité par défaut étant de 10, on peux supposer que ton tableau interne fasse les agrandissement 20,40,80,160,320,640,1280,2560,5120,10240,20480,... A chaque fois ça consomme du temps et de la mémoire. On peux éviter ça en passant par le constructeur ArrayList(int)

    Enfin, pour revenir à ta comparaison, dans le tableau tu stocke un million de double. Dans ton arraylist, tu crée et tu stocke un million d'Objets de type Double, ça consomme un supplément de temps.

  4. #4
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 551
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 551
    Points : 21 607
    Points
    21 607
    Par défaut
    À noter que dans le premier exemple, si on enlève la ligne a = dc2_copy3.get(j).start;, alors a reste à zéro et on a de bonnes chances de passer dans le if, ce qui fait sortir de la boucle immédiatement. Normal que ce soit plus rapide si on ne fait pas la boucle -_-°.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

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

Discussions similaires

  1. Requete SQL Anormalement lente
    Par ez3kiel dans le forum Requêtes
    Réponses: 1
    Dernier message: 04/05/2007, 21h45
  2. [SQL2000] Proc Stock anormalement lente
    Par guiooommm dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 21/03/2007, 15h51
  3. [Mail] Soumission anormalement lente
    Par gbnbcom dans le forum Langage
    Réponses: 18
    Dernier message: 10/01/2007, 13h47
  4. Connexion anormalement lente Active Directory 2003 Clien Win XP SP2
    Par digital prophecy dans le forum Windows Serveur
    Réponses: 1
    Dernier message: 11/11/2006, 22h07
  5. [Eclipse] Editeur de code trop lent
    Par Benzeghiba dans le forum Eclipse Java
    Réponses: 6
    Dernier message: 10/11/2005, 14h02

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