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

Interfaçage autre langage Python Discussion :

fuite mémoire Py_XDECREF


Sujet :

Interfaçage autre langage Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Février 2009
    Messages
    141
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 141
    Par défaut fuite mémoire Py_XDECREF
    Bonjour à tous,
    Bonjour Tamiel.

    Je viens de finir mon soft, mais lors de la mise en embarqué, je m'aperçois de fuite mémoire. Mon programme fonctionne pendant 30 min alors qu'il devrait fonctionner pendant des années.

    J'ai cerné le problème, tout mes allocations dynamiques sont détruites dans mon destructeur. Le problème donc viens de mes Py_XDECREF, j'en ai omis certain et je n'ai pas fais de PyFinalyse(). Ainsi, lorsque j'appelle mon main en boucle la mémoire augmente infiniment.

    Le problème lorsque j'essaie de faire mes Py_XDECREF sa plante, je ne sais pas pour qu'elle raison.

    Par ailleurs, je suis en C++ donc je possède des classe, dans ces différentes classes je fais intervenir plusieurs fois des Py_Initialyse(). Et mon Py_mod().

    Pour pallier à cela, j'ai mis mon Py_Initialyse() et Py_Finalyse() dans mon main. Ainsi, je n'ouvre qu'une seule fois l'instance du compilateur.

    Ensuite j'a commente qq milliers de ligne de code pour me ramener au principal
    J'ai ca dans un .cpp (pas le main)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    mymod = PyImport_ImportModule("interface");
    	PyObject* mdict = PyModule_GetDict(mymod);
    	PyObject* func5 = PyDict_GetItemString(mdict, "interoperability_Adding")
    PyObject* class_need_interoperability = PyEval_CallObject(func5,NULL);
     
     
    ..code commenté..
     
            Py_XDECREF(class_need_interoperability); Qd je met cette ligne ca me plante.
    	Py_XDECREF(func5);
    	Py_XDECREF(mdict);  
            Py_XDECREF(mymod);
    ;

    Tamiel as tu une idée.
    Je pense quand je serais d'où cela vient ca va ensuite allé vite.Je continue mes recherches.
    Merci beaucoup.
    Julien

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    271
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Décembre 2006
    Messages : 271
    Par défaut
    Ca plante comment ?

    Tu as quelque chose qui s'affiche ?

  3. #3
    Membre émérite
    Avatar de Antoine_935
    Profil pro
    Développeur web/mobile
    Inscrit en
    Juillet 2006
    Messages
    883
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur web/mobile

    Informations forums :
    Inscription : Juillet 2006
    Messages : 883
    Par défaut
    Si tu as les moyens de tester ça sur une machine conventionnelle, utilise Valgrind. Il pourra sans doute t'aider à trouver la fuite de mémoire.

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    271
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Décembre 2006
    Messages : 271
    Par défaut
    Un petit coup de gdb/ltrace/strace aidera aussi

  5. #5
    Membre confirmé
    Inscrit en
    Février 2009
    Messages
    141
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 141
    Par défaut
    Bonjour, désolé je n'ai pas pu répondre avant.
    Donc j'ai pu régler une partie du problème, une partie seulement.

    Au lieu de déclarer
    PyObject* class_need_interoperability = PyEval_CallObject(func5,NULL);
    J'ai directement mis PyEval_CallObject(func5,NULL) dans la fonction ou j'en avais besoin.
    J'ai d'ailleurs fait cela à chaque fois que j'avais le pb.

    Comme dit, j'utilise cette interfacage dans d'autre partie de mon soft. Et la par contre, ca plante qd j'invoque le Py_XDECREF(mymod);
    Est ce que c'est parce que j'invoque mymod plusieurs fois. Enfin je vais voir cela demain et vous redonner un feed back plus complet.

    Pour Valgrine je crois que c'est sous Linux.
    Mon soft est fait ss win, les autres de Tamiel je ne les connais pas.

    Bon merci à Tamiel et Antoine_935, à demain.

  6. #6
    Membre confirmé
    Inscrit en
    Février 2009
    Messages
    141
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 141
    Par défaut
    Bonjour,

    Alors voila, j'ai vraiment bien ciblé ma fuite mémoire.
    1)J'ai créer le moins de PyObject* possible, du coup, j'ai des noms à rallonge mais ce n'est pas grave.
    2)La fuite mémoire provient de la boucle for principalement. PyList_SetItem??
    3)Pour info : "InitListGenerators", "i", 2 * GeneratorPDict->size()) permet d'initialiser une liste dans mon Python pour la remplir. Cette liste est vide pour le moment. Elle va ensuite accueillir mon first puis second de ma map.

    4)Merci


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    PyObject* mymod = PyImport_ImportModule("interface");
    int CounterP =0;
    	for (MapOfStringDouble::iterator iterP =GeneratorPDict->begin(); iterP!=GeneratorPDict->end(); iterP++)
    	{
    		PyList_SetItem(PyObject_CallMethod(PyEval_CallObject(PyDict_GetItemString(PyModule_GetDict(mymod), "interoperability"),NULL), "InitListGenerators", "i", 2 * GeneratorPDict->size()), CounterP++, PyString_FromString(iterP->first.c_str()));
    		PyList_SetItem(PyObject_CallMethod(PyEval_CallObject(PyDict_GetItemString(PyModule_GetDict(mymod), "interoperability"),NULL), "InitListGenerators", "i", 2 * GeneratorPDict->size()), CounterP++, PyFloat_FromDouble(iterP->second));
     
        Py_XDECREF(mymod);
    	}

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

Discussions similaires

  1. [tomcat][memoire] java.net.URL et fuite mémoire
    Par Seiya dans le forum Tomcat et TomEE
    Réponses: 6
    Dernier message: 09/03/2009, 10h41
  2. [Fuites mémoire] Je cherche un utilitaire
    Par 10_GOTO_10 dans le forum C++Builder
    Réponses: 8
    Dernier message: 10/02/2005, 10h03
  3. Outil de recherche de fuite mémoire
    Par eag35 dans le forum MFC
    Réponses: 4
    Dernier message: 02/02/2005, 12h46
  4. [SWT]SWT et fuite mémoire(ou pas)
    Par menuge dans le forum SWT/JFace
    Réponses: 2
    Dernier message: 22/06/2004, 21h40
  5. [debug] fuites mémoires
    Par tmonjalo dans le forum C
    Réponses: 3
    Dernier message: 28/07/2003, 17h20

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