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 averti Avatar de Fooshi
    Homme Profil pro
    ICD
    Inscrit en
    Juin 2002
    Messages
    507
    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 : 507
    Points : 359
    Points
    359
    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 chevronné
    Homme Profil pro
    Dév. Java & C#
    Inscrit en
    Octobre 2002
    Messages
    1 413
    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 413
    Points : 1 993
    Points
    1 993
    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?
    Bien le bonjour chez vous
    Jowo

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    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 averti Avatar de Fooshi
    Homme Profil pro
    ICD
    Inscrit en
    Juin 2002
    Messages
    507
    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 : 507
    Points : 359
    Points
    359
    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 : 48

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    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
    bazar: http://www.improetcompagnie.com/publ...ctacles-6.html

    BÉPO la disposition de clavier francophone, ergonomique et libre: http://bepo.fr/wiki/Accueil

    Emacs Wiki: http://www.emacswiki.org/

    En attente de ce que produira: http://www.pushmid.com

  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 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 : 48

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    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.....
    bazar: http://www.improetcompagnie.com/publ...ctacles-6.html

    BÉPO la disposition de clavier francophone, ergonomique et libre: http://bepo.fr/wiki/Accueil

    Emacs Wiki: http://www.emacswiki.org/

    En attente de ce que produira: http://www.pushmid.com

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