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

Collection et Stream Java Discussion :

ArrayList et capacité initiale


Sujet :

Collection et Stream Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 172
    Par défaut ArrayList et capacité initiale
    Bonjour,

    je me pose une question sur la meilleure stratégie à adopter pour l'initialisation de la capacité d'une ArrayList.
    Par exemple si je sais que ma liste va contenir de 0 à 300 éléments, mais que ce nombre d'éléments est très variable selon les situations, est-ce que je dois plutot initialiser mon ArrayList à 300 ou dois-je choisir un plus petit nombre ?

  2. #2
    Membre Expert
    Avatar de Anthony.Desvernois
    Homme Profil pro
    Ingénieur sécurité & risque
    Inscrit en
    Juin 2007
    Messages
    1 489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur sécurité & risque
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 489
    Par défaut
    Bonjour,

    Pourquoi l'initialiser à une taille ? Tu n'es pas obligé et tu peux laisser java se charger de mettre à jour la taille directement (en général il fonctionne par "tranche" de 10).

  3. #3
    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 : 44
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Lorsque la taille de l'ArrayList devient insuffisante, la taille initiale est agrandie de 50%.
    A toi de voir selon ton application.
    Si la liste est extrêmement sollicitée, autant déclarer la taille max dès le début. Par contre, si la gestion de la mémoire est critique et que les objets dans la liste sont gigantesques, il faut une gestion plus fine de l'espace alloué pour le tableau et pourquoi pas créer son propre ArrayList.
    Mais dans la plupart des cas, il est inutile de s'occuper de ce genre de détails. Les problèmes de performances sont ailleurs, très souvent localisés entre la chaise et le clavier, un truc appelé "programmeur"
    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.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 172
    Par défaut
    Pourquoi l'initialiser à une taille ? Tu n'es pas obligé et tu peux laisser java se charger de mettre à jour la taille directement (en général il fonctionne par "tranche" de 10).
    Si tu sais que ta List va contenir 300 éléments, il est préférable d'initialiser la taille directement à 300 pour éviter les réallocations de mémoire qui sont gourmandes.
    Le problème est que parfois le nombre d'éléments d'une liste peut-être très variable, d'où ma question...

  5. #5
    Membre Expert
    Avatar de hasalex
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    879
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Janvier 2009
    Messages : 879
    Par défaut
    Personnellement, je n'initialiserais pas la taille. C'est le genre de paramètre qui ne sert qu'à de l'optimisation. Si tu veux optimiser, fais des tests comparatifs, en situation proche de la production, et tu pourras ainsi apporter la réponse à ta question dans ton propre contexte.

    En matière de performances, il est toujours dangeureux de vouloir s'appuyer sur des principes généraux...

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 172
    Par défaut
    C'est le genre de paramètre qui ne sert qu'à de l'optimisation.
    Nous sommes justement dans une phase d'optimisation
    Le mieux est surement de défnir la taille pour les listes dont on connait la taille et qui ne varient pas beaucoup. Pour le reste, c'est vrai qu'il faudrait des tests plus poussés, je vais donc laisser la valeur par défaut.
    Merci pour vos réponses.

  7. #7
    Membre éprouvé Avatar de nabodix
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 93
    Par défaut
    Globalement, tout à été dis.. mais je veux qd même confirmer :

    Si tu ne crée ton ArrayList sans spécifier la taille; il créera un tableau d'une taille de 10; ensuite, à chaque fois que tu rajouteras un élément qui dépassera la taille disponible il recréera un tableau en calculant sa nouvelle capacité ainsi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     int newCapacity = (oldCapacity * 3)/2 ;
    Il recopiera ensuite tous les éléments de l'ancien vers le nouveau tableau.

    Donc, si tu y rajoutes bcp d'éléments, il perdra inutilement son temps en recopiage de données, donc vaut mieux que tu déclares, si tu sais, une capacité initiale (et pas forcement 300, ou qu'importe ta taille maximum)..

    Pour 300 éléments je ne sais pas si cela fera une grande différence. par contre si tu en as plusieurs (centaines) d'arrayList ainsi, ca deviendrait plus intéressant.. (faudra alors choisir entre la mémoire et la performance..)

    Voilà... maintenant (bien que je suis assez sur de moi), je peux tjs me tromper

Discussions similaires

  1. ArrayList determiner sa capacité initiale
    Par drick35 dans le forum Android
    Réponses: 4
    Dernier message: 28/03/2013, 16h00
  2. Java dépassement de capacité ArrayList
    Par ritchie23 dans le forum Collection et Stream
    Réponses: 9
    Dernier message: 08/10/2008, 14h19
  3. [info]ArrayList
    Par schousso dans le forum Collection et Stream
    Réponses: 7
    Dernier message: 06/05/2004, 11h44
  4. [Fichier] Ajout des lignes de doc dans arraylist
    Par 3adoula dans le forum Entrée/Sortie
    Réponses: 9
    Dernier message: 29/04/2004, 22h41
  5. [ STRUTS ][ JSP ][ ArrayList] un lien pour trier
    Par LoulouFifi dans le forum Servlets/JSP
    Réponses: 7
    Dernier message: 03/02/2004, 17h24

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