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 :

constructeur et destructeur : pourquoi sont-ils nécessaires ?


Sujet :

C++

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    355
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 355
    Points : 0
    Points
    0
    Par défaut constructeur et destructeur : pourquoi sont-ils nécessaires ?
    bonjour,

    En langage C++,si je construis un objet pourquoi dois-je nécessairement établir un constructeur et un destructeur de cet objet ?


    merci de votre aide

  2. #2
    Expert éminent
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 565
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    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 565
    Points : 7 648
    Points
    7 648
    Par défaut
    Bonjour,

    Ça n'est absolument pas nécessaire de définir un constructeur ou le destructeur pour un objet.
    C'est d'ailleurs souvent une mauvaise idée de définir un destructeur (voir la règle des 5, autrefois appelée la règle des 3). Où as-tu entendu qu'ils doivent être nécessairement établis?

    Par contre, il ne faut pas oublier que si on ne les définit pas, le compilateur va les créer pour nous car quand un objet est créé, un de ses constructeurs est forcément appelé et quand il est détruit son destructeur est appelé. Quitte à ce que le traitement associé soit vide.

  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
    On définit un destructeur quand la classe gère elle-même la durée de vie d'une ressource (et pour être totalement exception-safe, il est conseillé de n'en gérer qu'une seule à la fois dans une classe). Dans tous les autres cas (y compris quand la classe possède des membres qui gèrent eux-mêmes des ressources, comme des unique_ptr), définir un destructeur n'est pas nécessaire.
    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
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 275
    Points : 10 985
    Points
    10 985
    Par défaut
    Pour nous, un constructeur est là pour positionner les invariants d'un objet.
    Cas particulier des ressources, le destructeur est là pour restituer les ressources acquises (mémoire, socket, fichier, mutex...)

    Pour le bien-être du binaire, le compilateur va toujours fournir tout ou parti de ces fonctions spéciales pour nous, même si on ne les spécifie pas. Ne serait que pour propager construction et destruction aux variables membres, et/ou aux types hérités.

    Quant aux bonnes pratiques, comme signalé, il faut déléguer au maximum la gestion des ressources à des classes que l'on appelle parfois capsules RAII. On retrouve la règle du 0/5 évoquée précédemment. Il reste donc à notre charge la construction initialisante à vocation de positionner les invariants métiers -- pour les invariants techniques, on essaie de déléguer au maximum donc.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 06/05/2007, 22h37
  2. Pourquoi les mails ne sont ils pas envoyés?
    Par Sunsawe dans le forum Développement
    Réponses: 3
    Dernier message: 12/04/2007, 23h49
  3. Pourquoi des titres de discussions sont-ils en gras et d'autres pas ?
    Par ybruant dans le forum Mode d'emploi & aide aux nouveaux
    Réponses: 2
    Dernier message: 16/11/2006, 15h22
  4. [WebForms][2.0] Pourquoi mes liens ne sont-ils pas valides ?
    Par ben_popcorn dans le forum Général Dotnet
    Réponses: 3
    Dernier message: 19/09/2006, 16h11
  5. [TClientSocket] Pourquoi sont-ils dépréciés ?
    Par Keke des Iles dans le forum Composants VCL
    Réponses: 4
    Dernier message: 06/01/2005, 15h47

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