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 :

utilité de void ensureCapacity(int)


Sujet :

Collection et Stream Java

  1. #1
    Membre du Club Avatar de Mr-Mobou
    Inscrit en
    Juin 2007
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 58
    Points : 65
    Points
    65
    Par défaut utilité de void ensureCapacity(int)
    je me demande l'utilité de la méthode void ensureCapacity(int)
    sachnat que l'augmentation de capacité se fait automatiquement si on dépasse la capacité de tableau

  2. #2
    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
    ca permet de gagner en performance lors des gros ajouts. Imaginons que tu aie une liste de 15 éléments, et tu veux y faire entrer 5000 éléments supplémentaires, un à un (tu ne dispose pas d'une autre liste pour faire un addAll par exemple).

    si tu laisse la liste grandir tout seul, le tableau interne va augmenter de taille d'un manière proche de la suivante
    25, 50, 100, 200, 400, 800, 1600, 3200, 6400 (faut voir les détails des calculs dans la classe, mais c'est proche de ça)

    ca veux dire que par 8 fois le tableau va être agrandit, alloué et copié. Si tu fais ça souvent, ce peux impliquer des pertes de performances. En pratique il est rare d'être dans un cas ou tu a besoin de gérer ça toi même, mais la méthode est disponible pour ces besoins spécifiques. Elle est aussi fortement utilisé en interne des classes poru agrandir le tableau

  3. #3
    Membre du Club Avatar de Mr-Mobou
    Inscrit en
    Juin 2007
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 58
    Points : 65
    Points
    65
    Par défaut
    merci pour votre réponse
    je cherche algorithme de calcul de capacité pour un arraylist est que quelqu'un a une indication ?

  4. #4
    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
    Il suffit de regarder le code source de ArrayList. Code de sun:
    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
        /**
         * Increases the capacity of this <tt>ArrayList</tt> instance, if
         * necessary, to ensure that it can hold at least the number of elements
         * specified by the minimum capacity argument.
         *
         * @param   minCapacity   the desired minimum capacity
         */
        public void ensureCapacity(int minCapacity) {
    	modCount++;
    	int oldCapacity = elementData.length;
    	if (minCapacity > oldCapacity) {
    	    Object oldData[] = elementData;
    	    int newCapacity = (oldCapacity * 3)/2 + 1;
        	    if (newCapacity < minCapacity)
    		newCapacity = minCapacity;
                // minCapacity is usually close to size, so this is a win:
                elementData = Arrays.copyOf(elementData, newCapacity);
    	}
        }
    C'est donc une augmentation par pas de 50%

  5. #5
    Membre du Club Avatar de Mr-Mobou
    Inscrit en
    Juin 2007
    Messages
    58
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 58
    Points : 65
    Points
    65
    Par défaut
    merci

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

Discussions similaires

  1. pointeur int vers void et retour de void vers int
    Par J4e8a16n dans le forum Débuter
    Réponses: 12
    Dernier message: 23/06/2009, 13h28
  2. Utilisation de public void add(int field, int amount)
    Par NFHnv dans le forum Débuter avec Java
    Réponses: 21
    Dernier message: 05/03/2009, 15h11
  3. fread(void*, int, int, FILE*)
    Par keil dans le forum C++
    Réponses: 11
    Dernier message: 25/01/2006, 22h13
  4. Convertir un void* en int ...?
    Par alex6891 dans le forum C++
    Réponses: 15
    Dernier message: 15/11/2005, 22h43
  5. [Débutant]#entre int main & void main
    Par Binga dans le forum C
    Réponses: 9
    Dernier message: 10/08/2004, 15h54

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