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

C++ Discussion :

Delete sur un tableaux d'objets


Sujet :

C++

  1. #21
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Par défaut
    C'est normal.

  2. #22
    Membre éclairé
    Homme Profil pro
    Architecte technique
    Inscrit en
    Février 2004
    Messages
    477
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 477
    Par défaut
    Pourquoi c'est normal ?

  3. #23
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Par défaut
    Un vecteur ne désalloue jamais la mémoire allouée, c'est plus performant si tu fais plusieurs opérations dessus.

    Si tu tiens réellement à ce que la mémoire allouée colle au nombre d'éléments, tu peux utiliser ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    std::vector<TCompareResult>(tabResult).swap(tabResult);
    PS : le erase ne sert à rien juste avant un clear (c'est exactement ce que ce dernier fait).

  4. #24
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par Pfeffer
    Donc j'ai suivi vos conseil pour parader ma fuite de mémoire! J'utilise les vector mais maintenant lorsque je veu supprimer son contenu, la mémoire allouée (gestionnaire des tâches) reste la même.
    Il y a au moins quatre niveaux d'allocation a considerer dans le cas present.

    Tout d'abord, il y a la memoire allouee par l'OS au processus. C'est celle que te permet de regarder le gestionnaire des taches.

    Ensuite il y a la memoire que ton programme a alloue et pas liberee. Ce n'est pas necessairement la meme chose, car le runtime pour repondre a une allocation que tu vas va demander a l'OS de la memoire, mais il peut en demander plus pour ne pas avoir a demander perpetuellement a l'OS d'une part, parce que l'OS a une granularite differente (l'OS alloue par page -- souvent 4 K, parfois plus -- ou par groupe de pages) d'autre part, finalement parce que la memoire que tu a liberee peux ne pas pouvoir etre rendue a l'OS meme si elle est de taille convenable (par exemple parce qu'elle ne se trouve pas au bon endroit).

    Les deux autres niveaux sont propres aux conteneurs de la bibliotheque standard.

    Ces conteneurs utilisent des allocateurs, qui peuvent jouer le meme jeux que l'allocateur du runtime: allouer plus que necesasire immediatement et ne pas rendre directement a l'allocateur du runtime.

    Quatriemement, les conteneurs eux-meme peuvent ne pas rendre la memoire directement a l'allocateur (difference entre capacity() et size()).

    Dans le cas present, clear() ne change pas le resultat de capacity(), donc on reste au quatrieme niveau. Il y a des bonnes chances que tu ne voies pas non plus de difference meme avec la technique donnee par Laurent, a cause des 3 autres niveaux.

  5. #25
    Membre éclairé
    Homme Profil pro
    Architecte technique
    Inscrit en
    Février 2004
    Messages
    477
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 477
    Par défaut
    Merci pour tous ses éléments de réponses mais maitenant comment est ce que je peux faire pour réduire cette fuite mémoire!

    En fait mon process maintenant, grâce au vector, ne prends pas beaucoup de mémoire (dans le gestionnaire des tâches). Entre 100 000 ko et 400 000 ko pendant l'opération. Et 100 000 ko à la fin de l'opération.

    Ceci dit au niveau de la chagre dédiée, l'évolution reste consante. 900 Mo à la fin de la deuxième opération.

    Je dois donc avoir quand même des fuites mémoires!

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. delete sur un tableau d'objets dans destructeur
    Par Mihnea24 dans le forum Débuter
    Réponses: 6
    Dernier message: 05/12/2008, 22h42
  2. delete[] seulement pour des tableaux d'objets?
    Par Crisanar dans le forum C++
    Réponses: 7
    Dernier message: 22/10/2005, 19h50
  3. Réponses: 2
    Dernier message: 19/08/2003, 18h04
  4. free sur des tableaux "a moitié dynamiques"
    Par barthelv dans le forum C
    Réponses: 4
    Dernier message: 31/07/2003, 15h30

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