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 :

Double free or corruption (out). Programmation d'une Pile.


Sujet :

C

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 33
    Points : 32
    Points
    32
    Par défaut Double free or corruption (out). Programmation d'une Pile.
    Bonjour,
    Je suis actuellement sur un projet de développement d'un Shell.

    Afin de gérer les appels à CD/POPD/PUSH/DIRS, j'ai du faire une pile.

    Donc j'ai essayé de m'inspiré de codes à droite à gauche, et apperement, quand on fait un pop, on doit faire un free pour supprimer l'élément.

    Le problème c'est que lorsque je fais appel une deuxieme fois à popd, ca me sort l'erreur Double free or corruption (out).

    D'après ce que j'ai vu, ca intervient quand on veut free 2 fois la meme zone mémoire, mais là je ne vois pas où je fais ça.

    Quand je commente la ligne du free, ca me fait une erreur de compilation au deuxieme appel :/.

    Voilà, je mets le code de ma Pile ici, si vous pouvez m'aider...

    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
     
    #include <stdio.h>
    #include <stdlib.h>
    #include "Pile.h"
     
     
     
    int stack_count(Pile **p_pile)
    {
      int i = 0;
      Pile *temporaire = (*p_pile)->precedent;
      if(p_pile != NULL)
    	{
    	  while(temporaire != NULL)
    		{
    		  i++;
    		  temporaire = temporaire->precedent;
    		}
    	}
      return i;
    }
     
    int stack_print(Pile **p_pile)
    {
     
      Pile *temporaire = (*p_pile)->precedent;
      if(p_pile != NULL)
    	{
    	  fprintf(stdout,"%s ", (*p_pile)->donnee);
    	  while(temporaire->precedent != NULL)
    		{
    		  fprintf(stdout,"%s ",temporaire->donnee);
    		  temporaire = temporaire->precedent;
    		}
    	  fprintf(stdout,"\n");
    	}
      return 0;
    }
     
     
    int stack_push(Pile **p_pile, char *donnee)
    {
      printf("on rentre ici \n");
      Pile *p_nouveau = malloc(sizeof *p_nouveau);
      if (p_nouveau != NULL)
    	{
    	  p_nouveau->donnee = donnee;
    	  p_nouveau->precedent = *p_pile;
    	  *p_pile = p_nouveau;
    	}
      return 0;
    }
     
     
    char *stack_pop(Pile **p_pile)
    {
      printf("on rentre dans pop \n");
      char *ret;
      if (p_pile != NULL)
        {
    	  Pile *temporaire = (*p_pile)->precedent;
    	  ret = (*p_pile)->donnee;  
    	  free(*p_pile), *p_pile = NULL;
    	  *p_pile = temporaire;
        }
      return ret;
    }
     
    char *stack_top(Pile *p_pile)
    {
      char *ret; /* Variable de retour */
      if (p_pile != NULL) /* Si la pile n'est pas nulle */
        {
    	  ret = p_pile->donnee; /* On stocke dans la variable ret, la valeur du dernier élément */
        }
      return ret;
    }

    Merci d'avance.

    Nieli

    N.B: Si vous avez besoin du reste du code, dites le moi.

  2. #2
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    stack_push :
    Est-ce que le paramètre passé en donnee est une chaîne de caractères en allocation dynamique ? Il serait préférable de faire dans la fonction l'allocation dynamique d'une chaîne suffisante (strlen(donnee)+1) et copier dedans la chaîne passée en paramètre.

    stack_pop :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
      char *ret= NULL;  // on peut ne pas entrer dans le if
      if (p_pile != NULL && *p_pile != NULL) // tester que la pile n'est pas vide

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 33
    Points : 32
    Points
    32
    Par défaut
    Franchement merci. J'avoue que je n'ai pas beaucoup d'expérience en C et je me suis cassé la tête toute l'aprem.

    Ma variable donnée n'était pas dynamique mais le simple fait de vérifier que la pile existe a résolu le problème.

    Encore merci.

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 17/05/2019, 17h27
  2. Réponses: 6
    Dernier message: 20/03/2009, 10h05
  3. [SFML] Image double free or corruption
    Par Belegkarnil dans le forum SFML
    Réponses: 4
    Dernier message: 23/08/2007, 16h56
  4. erreur glibc detected double free or corruption.
    Par Screwt-K dans le forum C++
    Réponses: 1
    Dernier message: 02/07/2007, 16h46
  5. Problème d'éxécution: double free or corruption
    Par ciol_tebroc dans le forum C++
    Réponses: 3
    Dernier message: 17/05/2006, 19h44

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