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 :

Liberation memoire chaine de caractere


Sujet :

C

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 41
    Points : 24
    Points
    24
    Par défaut Liberation memoire chaine de caractere
    Bonsoir a vous,

    Comment libérer l'espace mémoire occupée par la chaîne de caractère res?

    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
    char *CopieLigne (const char *s)
    {
     int k = 0;
     char *res = malloc(sizeof(char)*strlen (s));
     while (s[k]!='\n')
      {
       res[k] = s[k];
       k++;
      }
     return res;
    }
     
    int main (void)
    {
     char *origine = "Bonjour\nComment allez vous?\n";
     char *res = CopieLigne (origine);
     printf("%s\n",res);
     return 0;
    }
    De plus valgrind me donne se message

    ==4725== Conditional jump or move depends on uninitialised value(s)
    ==4725== at 0x401E215: strlen (mc_replace_strmem.c:246)
    ==4725== by 0x4088134: puts (in /lib/tls/i686/cmov/libc-2.3.6.so)
    ==4725== by 0x8048423: main

    Merci pour votre aide

  2. #2
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par BatuBou Voir le message
    Comment libérer l'espace mémoire occupée par la chaîne de caractère res?
    <...>
    De plus valgrind me donne se message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ==4725== Conditional jump or move depends on uninitialised value(s)
    ==4725==    at 0x401E215: strlen (mc_replace_strmem.c:246)
    ==4725==    by 0x4088134: puts (in /lib/tls/i686/cmov/libc-2.3.6.so)
    ==4725==    by 0x8048423: main
    Merci pour votre aide
    Déjà, tu peux corriger ça :
    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
     
    Project   : Forums
    Compiler  : GNU GCC Compiler (called directly)
    Directory : C:\dev\forums\
    --------------------------------------------------------------------------------
    Switching to target: default
    Compiling: main.c
    main.c: In function `CopieLigne':
    main.c:4: warning: implicit declaration of function `malloc'
    main.c:4: warning: implicit declaration of function `strlen'
    main.c: In function `main':
    main.c:15: warning: initialization discards qualifiers from pointer target type
    main.c:17: warning: implicit declaration of function `printf'
    main.c:19:2: warning: no newline at end of file
    Linking console executable: console.exe
    Process terminated with status 0 (0 minutes, 0 seconds)
    0 errors, 5 warnings
    http://emmanuel-delahaye.developpez....tm#cfg_compilo

    ensuite un simple free() de res dans le main suffit, sauf complications que je n'aurais pas vues...

    Quelques corrections :
    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
     
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    char *CopieLigne (const char *s)
    {
       int k = 0;
       /* -ed- de la place pour le 0 final */
       char *const res = malloc (strlen (s) +1);
       while (s[k] != '\n')
       {
          res[k] = s[k];
          k++;
       }
     
        /* -ed- le 0 final... */
          res[k] = 0;
       return res;
    }
     
    int main (void)
    {
       char const *origine = "Bonjour\n" 
                              "Comment allez vous?\n";
       char *res = CopieLigne (origine);
       if (res != NULL)
       {
          printf ("'%s'\n", res);
          free (res), res = NULL;
       }
       return 0;
    }
    Pose des questions si tu ne comprends pas.

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 41
    Points : 24
    Points
    24
    Par défaut
    Merci beaucoup pour votre reponse.

    J'ai vraiment besoin de rajouter les options de compilation pr mon gcc

    Bonne soirée a vous

  4. #4
    Membre actif
    Profil pro
    Dev
    Inscrit en
    Décembre 2007
    Messages
    191
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations professionnelles :
    Activité : Dev

    Informations forums :
    Inscription : Décembre 2007
    Messages : 191
    Points : 216
    Points
    216
    Par défaut
    Citation Envoyé par BatuBou Voir le message
    Merci beaucoup pour votre reponse.

    J'ai vraiment besoin de rajouter les options de compilation pr mon gcc

    Bonne soirée a vous
    -Wall (c-à-d afficher simplement tous les warnings) comme option est deja fortement conseillé

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 41
    Points : 24
    Points
    24
    Par défaut
    oui je compile tout le temps avec -Wall -ansi... Mais il m'a pas affiché tous ces warning lol.
    C'est pour ca que je vais rajouter les autres options

  6. #6
    gl
    gl est déconnecté
    Rédacteur

    Homme Profil pro
    Inscrit en
    Juin 2002
    Messages
    2 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 165
    Points : 4 637
    Points
    4 637
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    ensuite un simple free() de res dans le main suffit, sauf complications que je n'aurais pas vues...

    Quelques corrections :
    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
     
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    char *CopieLigne (const char *s)
    {
       int k = 0;
       /* -ed- de la place pour le 0 final */
       char *const res = malloc (strlen (s) +1);
       while (s[k] != '\n')
       {
          res[k] = s[k];
          k++;
       }
     
        /* -ed- le 0 final... */
          res[k] = 0;
       return res;
    }
     
    int main (void)
    {
       char const *origine = "Bonjour\n" 
                              "Comment allez vous?\n";
       char *res = CopieLigne (origine);
       if (res != NULL)
       {
          printf ("'%s'\n", res);
          free (res), res = NULL;
       }
       return 0;
    }
    Pose des questions si tu ne comprends pas.
    Personellement, j'aurais aussi rajoute un test sur la valeur de res (et donc sur le resultat de malloc) avant de l'utiliser.
    En outre, arreter la boucle lorsque la fin de chaine est atteinte me semble preferable pour gerer le cas ou il n'y a pas de '\n' dans la chaine initiale et eviter un debordement de buffer.

  7. #7
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par gl Voir le message
    Personellement, j'aurais aussi rajoute un test sur la valeur de res (et donc sur le resultat de malloc) avant de l'utiliser.
    En outre, arreter la boucle lorsque la fin de chaine est atteinte me semble preferable pour gerer le cas ou il n'y a pas de '\n' dans la chaine initiale et eviter un debordement de buffer.
    Oui, j'ai juste corrigé les bugs de bases. La fonction est améliorable, c'est sûr.

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Déjà, tu peux corriger ça :


    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    
    char *CopieLigne (const char *s)
    {
       int k = 0;
       /* -ed- de la place pour le 0 final */
       char *const res = malloc (strlen (s) +1);
       while (s[k] != '\n')
       {
          res[k] = s[k];
          k++;
       }
    
        /* -ed- le 0 final... */
          res[k] = 0;
       return res;
    }
    
    int main (void)
    {
       char const *origine = "Bonjour\n" 
                              "Comment allez vous?\n";
       char *res = CopieLigne (origine);
       if (res != NULL)
       {
          printf ("'%s'\n", res);
          free (res), res = NULL;
       }
       return 0;
    }
    A quoi ça sert de mettre res à NULL ??
    C'est en prévision du cas où on ne prendrait pas soin d'initialiser un futur malloc qui retomberait au même endroit ??

    Il y a pas des situations où cela est superflu de nettoyer les variables.

    Les programmeurs professionnels le font systématiquement ???

  9. #9
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Ca sert à indiquer que le pointeur ne pointe plus sur une région valide. Cela permet d'écrire ultérieurement par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    if (res == NULL)
    {
        /* res est libre, on va lui donner du boulot */
        ...
        res =  <...>;
        ...
    }
    else
    {
        /* res est encore occupe pour le moment, vaut mieux ne pas le deranger */
        ...
    }

  10. #10
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    Ok bon c'est utile selon les codes qu'on implémente.

    Mais bon je vais commençer quand même à prendre ça comme une habitude systématique .

    Ce qui est sûr , c'est que ça fera pas de mal à mon code


    PS : je crois que tu t'es trompé dans ton if , tu as inversé les conditions .

  11. #11
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Merci.
    Citation Envoyé par Black-Hawk
    Mais bon je vais commençer quand même à prendre ça comme une habitude systématique .

    Ce qui est sûr , c'est que ça fera pas de mal à mon code
    Oui ça fait partie des bonnes habitudes de programmation, d'ailleurs c'est très souvent utile.

  12. #12
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par Black-Hawk Voir le message
    A quoi ça sert de mettre res à NULL ??
    C'est en prévision du cas où on ne prendrait pas soin d'initialiser un futur malloc qui retomberait au même endroit ??
    Parce que c'est une Bonne Pratique

    http://emmanuel-delahaye.developpez.....htm#pointeurs
    Il y a pas des situations où cela est superflu de nettoyer les variables.
    Certainement.
    Les programmeurs professionnels le font systématiquement ???
    Moi, je le fais.

  13. #13
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 13
    Points : 12
    Points
    12
    Par défaut
    Très intéressant ton site qui doit sûrement regorger de pleins d'autres bonnes pratiques.

    Je le mets dans mes favoris.

    Merci de partager tout ça !!

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 06/11/2007, 12h36
  2. chaine de caracteres et memoire partagée
    Par iznogoud36 dans le forum C
    Réponses: 22
    Dernier message: 20/02/2007, 14h12
  3. memoire et chaine de caracteres
    Par hamma2 dans le forum Langage
    Réponses: 9
    Dernier message: 11/01/2007, 17h50
  4. Réponses: 44
    Dernier message: 18/05/2006, 16h19
  5. Probleme sur les chaines de caractere
    Par scorpiwolf dans le forum C
    Réponses: 8
    Dernier message: 06/05/2002, 19h01

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