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 :

perf des collections


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de menuge
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    727
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2004
    Messages : 727
    Par défaut perf des collections
    Salut à tous,

    je cherche un tuto ou un article sur les performances de l'utilisation des collections.
    Je cherche des infos du type: quel est l'impact de l'ajout d'un element dans un vecteur en comparaison avec l'ajout d'un element dans une ArrayList déjà initialisée.

    Merci d'avance

  2. #2
    Membre Expert
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Par défaut
    Citation Envoyé par menuge
    Salut à tous,

    je cherche un tuto ou un article sur les performances de l'utilisation des collections.
    Je cherche des infos du type: quel est l'impact de l'ajout d'un element dans un vecteur en comparaison avec l'ajout d'un element dans une ArrayList déjà initialisée.

    Merci d'avance
    Knuth: "the art of computer programming" ça parle même pas de Java ....

  3. #3
    Membre Expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Par défaut
    Tu peux faire le test toi-même, tu insères et supprime 10 millions de fois un élément dans un Vector, et tu fais pareil dans une ArrayList, et tu chronomètres

  4. #4
    Membre Expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Par défaut
    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
    public static void main(String[] args) {
            Object o = new Object();
            Vector v = new Vector();
            ArrayList a = new ArrayList();
     
            long t = System.nanoTime();
            for(int i = 0 ; i < 10000000; i++) {
                v.add(o);
                v.remove(o);
            }
            System.out.println("Vector   : " + (System.nanoTime() - t));
     
            t = System.nanoTime();
            for(int i = 0 ; i < 10000000; i++) {
                a.add(o);
                a.remove(o);
            }
            System.out.println("ArrayList: " + (System.nanoTime() - t));
     
        }
    Mon résultat:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Vector   : 930280245
    ArrayList: 476021673
    ArrayList deux fois plus rapide...

  5. #5
    Membre chevronné
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    365
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Janvier 2006
    Messages : 365
    Par défaut
    La grande différence entre Vector et ArrayList c'est que les méthodes de Vector sont synchronized, ce qui fait une charge supplémentaire et donc plus de lenteur par rapport à ArrayList.

  6. #6
    Membre Expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Par défaut
    D'ailleurs, les classes Vector, Hashtable et autres anciennes collections sont à bannir...

    Si tu veux un truc synchronisé, tu fais une arraylist et tu passes par Collections.synchronizedXXX(...).

Discussions similaires

  1. Réponses: 4
    Dernier message: 11/01/2008, 11h26
  2. usage des collections
    Par AlexFred dans le forum Access
    Réponses: 2
    Dernier message: 29/01/2007, 17h41
  3. probleme sur la gestion des collections
    Par joelc dans le forum ASP
    Réponses: 1
    Dernier message: 24/08/2006, 14h19
  4. Réponses: 6
    Dernier message: 22/05/2006, 20h12
  5. Réponses: 1
    Dernier message: 03/10/2005, 14h46

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