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 :

de l'initialisation des membres statiques (dont l'un depend de l'autre)


Sujet :

C++

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 7
    Points : 7
    Points
    7
    Par défaut de l'initialisation des membres statiques (dont l'un depend de l'autre)
    Bonjour,
    Je fais suite à un précédent post, résolu, dans lequel je voulais initialiser un membre statique Date::todayd.
    Je voudrais aussi initialiser un autre membre statique Date::today_init indiquant si l'initialisation de Date::todayd a fonctionné.
    J'écris donc le code suivant :

    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
    namespace {
    Date InitToday(bool &success){
    [...] //initialisation de today, qui peut ne pas marcher et lever une exception.
    // success=true si ca a marché
     }
    }
     
    bool success = false;
    Date Date::todayd = InitToday(success); // **(1)
    bool Date::today_init=success; // **(2)
     
    const Date& Date::today() {
      if (!today_init)
         throw Bad_date();
      return todayd;
    }
    Pourtant, en lisant la FAQ sur l'initialisation des variables statiques, j'ai un doute. Si je comprends bien il n'y a pas de guarantie sur l'ordre de l'initialisation; càd **(2) pourrait etre executé avant **(1), et donc today_init aurait un mauvais état. Est-ce que je comprends bien ?
    Si c'est bien le cas alors mon code est incorrect.
    Je cherche une solution pour initialiser à coup sûr ces deux membres en un seul coup, sachant que today_init depend de ce qui s'est passé pour l'initialisation de todayd.
    Mais pour l'instant je ne vois pas.
    J'avais pensé à setter Date::today_init=true dans InitToday(), mais today_init est un attribut privé de Date, et je souhaite le conserver ainsi.

    Quelqu'un aurait un conseil ou une idée à me donner à ce sujet ?
    Merci aux experts !

  2. #2
    Inactif  
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    743
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 743
    Points : 460
    Points
    460
    Par défaut
    Suggestion: Définir une classe avec les variables membres que tu souhaites, et avec un constructeur qui initialise ces variables dans le bon ordre.
    Et tu n'as plus à instancier qu'une seule classe statique.

  3. #3
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    Il me semble que dans une même unité de compilation, l'ordre d'initialisation des variables statiques est bien défini. Par contre je ne sais pas si l'ordre qui est pris est celui de leur déclaration, ou celui de leur définition. J'aurais plutôt tendance à dire que c'est celui de leur déclaration.

  4. #4
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 860
    Points
    11 860
    Par défaut
    Et pourquoi ne pas faire une fonction membre InitDate dans Date, où tu mettrais le code d'initialisation de tes statiques.
    Dans ce cas là, il me semble que tes initialisations se feront dans le bon ordre, de manière certaine. Et tant qu'à faire, quand tu les déclares dans ta classe, mets les dans le même ordre que celui avec lequel tu les initialises.

    ( tu as lu http://c.developpez.com/faq/cpp/inde...prevent_membre ? )

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 258
    Points : 307
    Points
    307
    Par défaut
    Citation Envoyé par Laurent Gomila
    Il me semble que dans une même unité de compilation, l'ordre d'initialisation des variables statiques est bien défini. Par contre je ne sais pas si l'ordre qui est pris est celui de leur déclaration, ou celui de leur définition. J'aurais plutôt tendance à dire que c'est celui de leur déclaration.
    Ils sont initialisés dans l'ordre de leur définition :
    Citation Envoyé par Standard, 3.6.2-1
    Objects with static storage duration defined [...] in the same translation unit [...] shall be initialized in the order in which their definition appears in the translation unit.

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    Merci pour la précision roulious.
    Donc a priori mon code initial est correct

    Pour info j'ai trouvé un très bon article sur l'initialisation statique des variables en c++. Ca vaut la peine de le lire.

    Dans certains cas ou les membres statiques sont accessibles de l'exterieur de la classe (ce n'est pas mon cas) il faut parfois mieux passer par une classe amie d'initialisation :

    http://aips2.nrao.edu/daily/docs/notes/173.text

    merci à tous

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 12/03/2013, 13h23
  2. Error de link sur des membres statiques définis
    Par chr.charles dans le forum C++
    Réponses: 3
    Dernier message: 25/02/2011, 09h56
  3. Initialisation de membres statique
    Par sopsag dans le forum Général Python
    Réponses: 4
    Dernier message: 12/01/2011, 17h54
  4. Réponses: 16
    Dernier message: 09/08/2010, 11h14
  5. [syntaxe] initialisation des membres
    Par ZaaN dans le forum C++
    Réponses: 2
    Dernier message: 21/11/2006, 09h34

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