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 :

Malloc et Macro ne font pas bon menage ?


Sujet :

C

  1. #1
    Membre éclairé Avatar de Fooshi
    Homme Profil pro
    ICD
    Inscrit en
    Juin 2002
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : ICD
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2002
    Messages : 508
    Par défaut Malloc et Macro ne font pas bon menage ?
    bonjour,
    je souhaite remplacer plusieurs lignes de codes par une macro :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    	if (msg)
    		{
    			msg[msg_len] = '\0';
    			break;
    		}
    		msg_len++;
    		msg = (char *) malloc(msg_len);
    		if (check_not(msg != NULL, "Can't alloc msg"))
    		{
    			return -1;
    		}
    ci dessous ma macro qui la remplace :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    #define END_MSG(msg, msg_len) \
    	do { \
    		if (msg) \
    		{ \
    			msg[msg_len] = '\0'; \
    			break; \
    	    } \
    		msg_len++; \
    		msg = (char *) malloc(msg_len); \
    		if (check_not(msg != NULL, "Can't alloc msg")) \
    		{ \
    			return -1; \
    		} \
    	} while(0)
    la macro me donne un problème , autrement dis l'allocation mémoire ne se fais pas ! (j'ai bien essaye if (msg == NULL) ... )

    ma macro est t'elle mal écrite ?
    Merci d'avance.

  2. #2
    Membre Expert
    Homme Profil pro
    Dév. Java & C#
    Inscrit en
    Octobre 2002
    Messages
    1 414
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Dév. Java & C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 414
    Par défaut
    Bonjour,

    Pour les macros, la bonne pratique consiste à entourer par des parenthèses les paramètres de la macro.

    Mais attention aux cas particuliers. Il me semble que tu les a cumulée dans ta macro.

    Une bonne macro est une macro courte.

    Ton return dans une macro ne me plait pas beaucoup.

    Comment utiles-tu la macro?

    Pourquoi ne pas écrire une fonction?

  3. #3
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 393
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    Fais gaffe, le do-while a changé la signification du break...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  4. #4
    Membre éclairé Avatar de Fooshi
    Homme Profil pro
    ICD
    Inscrit en
    Juin 2002
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : ICD
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2002
    Messages : 508
    Par défaut
    Ca doit etre ca, je vais ecrire une fonction. Merci quand meme

  5. #5
    Membre Expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Par défaut
    Ce que je vois en indentant ta macro

    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
     
    #define END_MSG(msg, msg_len)                          \
         do {                                             \
           if (msg)                                       \
             {                                            \
               msg[msg_len] = '\0';                       \
               break;                                     \
             }                                            \
           msg_len++;                                     \
           msg = (char *) malloc(msg_len);                \ <--- Risque de memory leak car tu perd la référence précendent à msg.
           if (check_not(msg != NULL, "Can't alloc msg")) \
             {                                            \
               return -1;                                 \
             }                                            \
         } while(0)
    C'est que ton malloc est fait de facon systematique que msg soit NULL ou non.
    tu as un risque de memory leak ici.

    malloc et les macro n'ont pas de soucis particulier.
    j'ai fait le test suivant et ça marche.
    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
     
    #include <stdio.h>
     
    #define CMSG(msg, msg_len)                                  \
      if (msg == NULL) {                                        \
        msg = malloc(msg_len+1);                                  \
      }                                                         \
      if (msg == NULL) {                                        \
        printf("Erreur d'allocation\n");                        \
      }                                                         \
      for(i=0;i<msg_len;i++) {                                  \
        msg[i] = 'a' + i ;                                      \
      }                                                         \
      msg[msg_len] = '\0';      
     
     
     
     
    int main (int argc, char ** argv) {
      int i = 0;
      char * wasa = NULL;
      char * toto = NULL;
      CMSG(wasa,17);
      CMSG(toto,5);
      printf("%s - %s\n", wasa , toto);
     
     
      return 0;
    }

    -*- mode: compilation; default-directory: "c:/" -*-
    Compilation started at Thu Jul 01 16:36:59

    gcc toto.c -o toto && toto
    abcdefghijklmnopq - abcde

    Compilation finished at Thu Jul 01 16:37:00

  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 : 46
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 165
    Par défaut
    Citation Envoyé par jabbounet Voir le message
    Ce que je vois en indentant ta macro

    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
     
    #define END_MSG(msg, msg_len)                          \
         do {                                             \
           if (msg)                                       \
             {                                            \
               msg[msg_len] = '\0';                       \
               break;                                     \
             }                                            \
           msg_len++;                                     \
           msg = (char *) malloc(msg_len);                \ <--- Risque de memory leak car tu perd la référence précendent à msg.
           if (check_not(msg != NULL, "Can't alloc msg")) \
             {                                            \
               return -1;                                 \
             }                                            \
         } while(0)
    C'est que ton malloc est fait de facon systematique que msg soit NULL ou non.
    tu as un risque de memory leak ici.
    Non, malloc() n'est pas fait de façon systématique ici. Si msg n'est pas NULL, on sort de la boucle (et donc malloc() n'est pas exécuté) avec le break.

  7. #7
    Membre Expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Par défaut
    Citation Envoyé par gl Voir le message
    Non, malloc() n'est pas fait de façon systématique ici. Si msg n'est pas NULL, on sort de la boucle (et donc malloc() n'est pas exécuté) avec le break.
    oups j'avais de la #ù$**** dans les yeux.....

Discussions similaires

  1. [DisplayTag] Tri et pagination ne font pas bon ménage
    Par tiboudchou dans le forum Taglibs
    Réponses: 4
    Dernier message: 31/03/2010, 12h22
  2. Le wifi et Club Internet ne font pas bon ménage!
    Par Ylias dans le forum La taverne du Club : Humour et divers
    Réponses: 5
    Dernier message: 20/08/2007, 10h30
  3. Réponses: 2
    Dernier message: 12/08/2007, 15h27
  4. [AJAX] multithreads et sessions PHP ne font pas bon ménage !
    Par Tanhys dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 29/10/2006, 15h47
  5. update et where font pas bon menage!!
    Par kleenex dans le forum Access
    Réponses: 5
    Dernier message: 30/09/2005, 17h45

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