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 :

consommation mémoire inexplicable ?


Sujet :

C

  1. #1
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut consommation mémoire inexplicable ?
    Bonjour,


    J'ai un gros soucis... dans un programme j'effectue quelques allocations dynamiques, puis lance un long calcul itératif qui utilise des variables déjà déclarées (aucun appel de fonction ou allocation n'a lieu)

    pourtant, cette boucle semble consommer énormement de mémoire : 1Go alors qu'avec un nombre raisonnable d'itérations je tombe à 300Ko

    je ne mets pas de code, car il s'agit d'un interpréteur de bytecode, assez compliqué à décortiquer... avec du code créé dynamiquement, ce qui rend gdb inutilisable à ce moment

    a priori, que chercheriez-vous pour trouver l'origine du problème ?
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    309
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 309
    Par défaut
    Est-ce qu'il n'y a pas de fuite mémoire ? N'oublies-tu pas d'utiliser la fonction free() sur des pointeurs dont tu n'aurais plus besoin ou pire que tu modifies ?

  3. #3
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    j'alloue dynamiquement deux tableaux dont j'ai besoin jusqu'à la fin, et un bloc de code binaire, que je garde car il peut servir à la prochaine itération de la boucle... ça fait 3 malloc avant la boucle, pas de free avant la fin de l'exécution du bytecode, mais aucun malloc durant l'itération
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  4. #4
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 978
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 978
    Par défaut
    Kao,

    Quelle profondeur d'itération atteins-tu ?

    Ta fonction itérative utilise-t-elle des variables locales ?

  5. #5
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    j'atteinds 30000 itérations en consommant 500Mo de données, et je ne déclare pas de variable locale... j'ai une variable globale qui représente ma pile, et que je parcours et modifie si besoin
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 403
    Par défaut
    Ta pile, a-t-elle la forme d'un tableau de taille limitée ou peut-elle s'étendre à l'infini ?
    Et tu es sûr de ne rien leaker dessus ?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    Citation Envoyé par Médinoc
    Ta pile, a-t-elle la forme d'un tableau de taille limitée ou peut-elle s'étendre à l'infini ?

    ma pile est un int[255], et mes bytecodes sont alloués une seule fois via un malloc au tout début du programme...

    je pourrais avoir 2 mallocs supplémentaires, l'un pour l'insertion dans un AVL pour déclarer un bloc et l'autre pour la construction du bloc... les deux fonctions faisant cela log sur stderr, et je constate qu'une fois que je commence l'itération, je ne les appelle plus


    Citation Envoyé par Médinoc
    Et tu es sûr de ne rien leaker dessus ?
    je n'ai pas bien compris la question...
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  8. #8
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 403
    Par défaut
    je n'ai pas bien compris la question...
    Pas grave, avec un int[255], la seconde question n'a plus vraiment d'intéret.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  9. #9
    Membre confirmé Avatar de Beldom
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 63
    Par défaut
    memory leak : fuite de mémoire.

    Quelles fonctions utilises-tu dans ta boucle ?
    Es-tu certain qu'aucune n'alloue quelque chose en mémoire ?

  10. #10
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    Citation Envoyé par Beldom
    Quelles fonctions utilises-tu dans ta boucle ?
    Es-tu certain qu'aucune n'alloue quelque chose en mémoire ?

    aucune justement... ma boucle n'est pas une boucle au sens de c, mais l'exécution d'un bloc dynamique qui fait un goto vers son commencement, puis un test pour savoir s'il sort, ou s'il continue une itération suivante... et les opérations effectuées sont des modifications sur deux variables globales

    sachant que lorsque je construis le même bloc "à la main", l'exécution se déroule sans problème

    je peux éventuellement mettre le code, mais ce sera un peu long, et je ne sais pas trop ce qui bug, donc ça ne sera pas lisible sur le forum... où alors je mets en pièce jointe, pour que vous puissiez regarder sur vos machines
    (le code ne marche que sur plate-forme unix x86 32bits en revanche )
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  11. #11
    Membre confirmé Avatar de Beldom
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 63
    Par défaut
    A la limite, oui, donne nous le code en pièce jointe, qu'on puisse essayer de trouver...
    Parce que là, comme ca, je ne vois pas du tout ce qui peut clocher ou en tout cas provoquer une telle consomation en mémoire...

    Je suis pas sûr d'avoir accès à une machine qui me permette de le compiler/tester, mais ca pourra quand même aider

  12. #12
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    je pense que Jean-Marc t'avait suggéré que tu passais plus de temps à essayer de faire ça qu'à coder directement

    Et visiblement il y a d'autres problèmes

  13. #13
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    et ben le voilà

    il "manque" deux fichiers, qui ne sont pas utiles pour ce problème


    il faut activer les flags BLOCK_INTERPRET et BLOCK_ON_FLOW pour avoir le programme qui pose problème
    Fichiers attachés Fichiers attachés
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  14. #14
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    eureka... j'ai trouvé


    il y a une déclaration d'une variable dans chaque itération, elle me servait normalement uniquement dans le code préliminaire à la construction du bloc, mais appartenait à la fonction bloc_GOTO, qui devait certainement l'allouer systématiquement au début de la fonction, et non uniquement quand je rentrais dans le else en question...

    j'ai donc fait un malloc, et un free au lieu d'une déclaration statique, et ça passe...
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

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

Discussions similaires

  1. Voir la consommation mémoire
    Par MicroPuce dans le forum Général Java
    Réponses: 4
    Dernier message: 10/10/2006, 10h19
  2. [C#] probleme de consommation mémoire
    Par xtream dans le forum Windows Forms
    Réponses: 3
    Dernier message: 21/06/2006, 14h16
  3. [TStringGrid] Consommation mémoire
    Par spender dans le forum Bases de données
    Réponses: 4
    Dernier message: 09/03/2006, 22h48
  4. [Consommation mémoire] Quoi utiliser pour trouver?
    Par doudine dans le forum Interfaces Graphiques en Java
    Réponses: 1
    Dernier message: 25/01/2006, 14h50
  5. Réponses: 4
    Dernier message: 09/11/2005, 14h32

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