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 :

"pointer being freed was not allocated"


Sujet :

C

  1. #1
    Candidat au Club
    Homme Profil pro
    Technicien du Son
    Inscrit en
    Février 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Technicien du Son

    Informations forums :
    Inscription : Février 2017
    Messages : 2
    Par défaut "pointer being freed was not allocated"
    Bonjour a tous,

    Je suis entrain d'essayer de free un **tab mais j'obtiens une erreur me disant que je tente de free quelque chose qui n'est pas alloué...
    "pointer being freed was not allocated"

    Voici mon code:
    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
     
    #include <stdio.h>
    #include <stdlib.h>
     
    void		print_tab(char **tab)
    {
    	int		i;
     
    	i = 0;
    	while (tab[i])
    	{
    		printf("%s\n", tab[i]);
    		i++;
    	}
    }
     
    char		**fill_tab(char **tab)
    {
    	tab[0] = "str1";
    	tab[1] = "str2";
    	return (tab);
    }
     
    char		**malloc_tab(char **tab, int nb_str, int nb_char)
    {
    	int		i;
    	int		j;
     
    	i = 0;
    	tab = malloc(sizeof(char *) * nb_str);
    	tab[nb_str - 1] = 0;
    	while (tab[i])
    	{
    		tab[i] = malloc(sizeof(char) * nb_char);
    		i++;
    	}
    	return (tab);
    }
     
    void		free_tab(char **tab)
    {
    	int		i;
     
    	i = 0;
    	printf("%s", tab[2]);
    	while (tab[i])
    	{
    		printf("tab[%d]", i);
    		free(tab[i]);
    		i++;
    	}
    	free(tab);
    }
     
    int	main(int argc, char **argv)
    {
    	char	**tab;
     
     	tab = malloc_tab(tab, 3, 6);
    	tab = fill_tab(tab);
    	print_tab(tab);
    	free_tab(tab);
    	return (0);
    }
    Merci pour votre aide !

  2. #2
    Expert confirmé
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 599
    Par défaut
    Ligne 32, on lit la valeurs des tab[i], mais tab vient juste d'être alloué donc les valeurs tab[i] sont encore non remplies donc ont des valeurs aléatoires.

  3. #3
    Candidat au Club
    Homme Profil pro
    Technicien du Son
    Inscrit en
    Février 2017
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Technicien du Son

    Informations forums :
    Inscription : Février 2017
    Messages : 2
    Par défaut
    Merci daflab !

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

Discussions similaires

  1. [QUOTE]SQLSTATE[HY093]: Invalid parameter number: parameter was not defined
    Par MInfo25 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 01/08/2017, 22h51
  2. Réponses: 3
    Dernier message: 23/01/2006, 16h29
  3. Réponses: 14
    Dernier message: 23/08/2004, 07h53
  4. [Génération] The dialect was not set
    Par sylvain_neus dans le forum Hibernate
    Réponses: 8
    Dernier message: 17/03/2004, 10h57
  5. requested URL /forms90/f90servlet was not found
    Par Aeternus dans le forum Oracle
    Réponses: 11
    Dernier message: 03/02/2004, 16h45

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