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 :

process returned -1073741819 lors d'un malloc


Sujet :

C

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2
    Par défaut process returned -1073741819 lors d'un malloc
    Bonjour à tous, voici mon problème : représenter en langage C des B-arbres, et implémenter une fonction d'insertion de valeurs.

    J'ai donc créé ma structure comme suit :
    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
     
    //Structure des B-arbres
    typedef sommet *arbre;
    typedef struct
    {
        int val;
        arbre fils;
    }Tval;
    typedef struct sommet
    {
        int nb_val;
        arbre premFils;
        Tval tab_val[2*N];
        arbre pere;
    }sommet;
    Le principe expliqué rapidement :

    Une structure sommet contenant :
    Le nombre de valeurs contenus dans le tableau tab_val(2*ordre du B-arbre).
    Un pointeur sur le premier fils, de type *sommet.
    Un tableau de Tval contenant (2*ordre) valeurs et (2*ordre) pointeurs sur un fils de type *sommet.
    Un pointeur sur l'arbre père.


    Afin de m'y retrouver dans tout ça, et pour ne pas avoir de valeurs incongrues si je ne remplis pas entièrement chaque feuille, j'ai implémenté une fonction me permettant d'initialiser tous les pointeurs de ma structure à NULL, et toutes les valeurs à 0.


    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
     
    arbre init()
    {
        int i;
        printf("ICI1 \n");
        arbre A = malloc(sizeof(arbre));
        if (A == NULL)
            printf("Plus de place! Malloc impossible \n");
        printf("ICI2 \n");
        A->premFils = NULL;
        A->pere = NULL;
        A->nb_val = 0;
        for(i=0;i<(2*N);i++)
        {
            A->tab_val[i].fils = NULL;
            A->tab_val[i].val = 0;
        }
        return A;
    }

    Comme vous pouvez le constater, elle n'a pas de paramètres, mais renvoie un arbre.
    J'alloue l'espace mémoire nécessaire, et je fais les opérations décrites ci-dessus.
    Les deux printf("Je suis ici \n"); me servent à tester/débugger mon programme. Je m'explique :

    En prenant comme main ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    int main()
    {
        arbre A = init();
        system("pause");
        arbre B = init();
        system("pause");
        printf("OK \n");
        return 1;
    }
    Tout se passe comme prévu, sans erreur, et le programme retourne 1 en quittant.
    Si maintenant, je prends comme main :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    int main()
    {
        arbre A = init();
        system("pause");
        arbre B = init();
        system("pause");
        arbre C = init();
        system("pause");
        printf("OK \n");
        return 1;
    }
    A ce moment là, les deux premiers malloc se passent bien, mais le troisième appel à init() fait planter mon programme, et retourne -1073741819 <0xC0000005>.

    En fait, les deux printf me permettent d'affirmer que le problème vient du malloc, étant donné que les deux premières fois, l'affichage est bien :
    ICI1
    ICI2
    Appuyez sur une touche pour continuer...(du fait de mon system("pause"))
    ICI1
    ICI2
    Appuyez sur une touche pour continuer...(du fait de mon system("pause"))
    ICI1

    Process returned etc.etc.


    J'en appelle donc à vous, amis et experts programmeurs!
    Sauriez-vous d'où peut venir cette erreur?


    Merci d'avance!
    (Elève en Licence 3 informatique, sujet de TP en algorithme et structure de données).

  2. #2
    Invité(e)
    Invité(e)
    Par défaut
    Bonjour,

    Je n'ai pas regardé en détail tout le code, mais une chose retient mon attention :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    arbre A = malloc(sizeof(arbre));
    Le type arbre est un pointeur donc sa taille doit être 4 sur une archi 32 bits.

    Remplace la ligne par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    arbre A = malloc(sizeof(sommet));
    EDIT : ou une variante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    arbre A = malloc(sizeof(sommet));
    /* ou */
    arbre A = malloc(sizeof(*arbre));
    /* ou */
    arbre A = malloc(sizeof *A );
    Ma préférence va pour la dernière forme : si tu change le type de 'A', tu n'aura qu'une modification à faire dans la ligne de code.

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2
    Par défaut
    Citation Envoyé par mabu Voir le message
    Remplace la ligne par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    arbre A = malloc(sizeof(sommet));
    Bonjour, et merci du coup de main!

    Effectivement, plus de problèmes de malloc depuis que j'ai changé le type, c'est vrai que 'arbre' faisait référence à un pointeur.

    (Impossible de modifier mon premier message pour afficher que c'est résolu, si quelqu'un peut passer le faire, ce serait sympa! ).

  4. #4
    Invité(e)
    Invité(e)
    Par défaut
    Citation Envoyé par Anadir Voir le message
    (Impossible de modifier mon premier message pour afficher que c'est résolu, si quelqu'un peut passer le faire, ce serait sympa! ).
    Sans éditer ton premier message, clique juste sur (en bas à gauche de tête)

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

Discussions similaires

  1. Process returned 255
    Par Tokapi dans le forum C
    Réponses: 5
    Dernier message: 20/12/2011, 00h18
  2. "Process returned 3" (kézako?!?)
    Par Nival dans le forum Débuter
    Réponses: 6
    Dernier message: 15/03/2009, 01h48
  3. Réponses: 2
    Dernier message: 21/05/2008, 03h18
  4. probleme free heap block lors d'un malloc
    Par gronaze dans le forum C
    Réponses: 2
    Dernier message: 24/03/2006, 15h01
  5. Process a 25% (lors d'un query utilisant un subselect)
    Par zeavan dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 12/01/2006, 11h46

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