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

Langage Java Discussion :

Héritage: comment appeler le constructeur parent ?


Sujet :

Langage Java

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut Héritage: comment appeler le constructeur parent ?
    Bonjour à Tous, j'ai une architecture qui a environ cette structure:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    class A{
        public A() {}
        public A(double, enum) {}
        //J'ai beaucoup d'autres constructeurs
    }
     
    abstract class B extends A{
        public B(double, enum) { super(double, enum); }
    }
     
    class C extends B{
        public C(double, enum) { super(double, enum); }
    }
    Je n'ai pas tout montré mais en gros, ça m'embête de devoir répéter tous les constructeurs de A dans B pour pouvoir l'utiliser depuis C, du coup j'aimerais savoir s'il y a moyen d'appeler directement le constructeur de A depuis C, sans passer par super ?

    Merci d'avance

  2. #2
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,


    Non il faut passer par super...

    a++

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    Salut ça veut dire qu'il faut obligatoirement que je redéfinisse tous mes constructeurs de A dans B ? :-(

  4. #4
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Oui...


    a++

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    C'est un peu à chier comparé à C++ non ? ...

  6. #6
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    A titre tout à fait personnel c'est plutôt l'approche "Orienté Objet" du C++ qui est "à chier"...

    a++

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    Qu'est-ce qui te fait dire ça ?

  8. #8
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 586
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 586
    Par défaut
    Bah, c'est simple : un objet ne peut pas à la fois étendre une classe, et se passer d'appeler un de ses constructeurs (ce que permet C++, en substance.)

    C'est l'un ou c'est l'autre, pas les deux à la fois.

    (Après, peut-être qu'un raccourci pour dire "définir un constructeur pour chacun des constructeurs de ma classe mère, avec la même signature et qui se contente d'appeler super dessus," pourrait servir dans certains cas de POJOs très simples et bien organisés.)
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  9. #9
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 966
    Par défaut
    Sous Eclipse : clic droit, source, generate constructors from superclass.

  10. #10
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    Je ne vois pas le problème d'appeler le constructeur de A depuis C, je trouve que c'est plus une limitation qu'autre chose de ne pouvoir appeler que le constructeur de la classe directement héritée.

  11. #11
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par scheme Voir le message
    Qu'est-ce qui te fait dire ça ?
    Je ne trouve pas cohérent que l'on puisse appeler directement le constructeur de la classe "grand parent".

    a++

  12. #12
    Membre chevronné
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2010
    Messages
    158
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2010
    Messages : 158
    Par défaut
    Citation Envoyé par scheme Voir le message
    Je ne vois pas le problème d'appeler le constructeur de A depuis C, je trouve que c'est plus une limitation qu'autre chose de ne pouvoir appeler que le constructeur de la classe directement héritée.
    Dans ton cas, où les constructeurs de B ne contiennent aucun code, tu ne vois pas le problème.
    Mais supposons que B initialise des données dans son constructeur, alors C ne pourrait pas se permettre de court-circuiter le constructeur de B...

    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
    class A
    {
    	public final int a;
     
    	public A(int a)
    	{
    		this.a = a;
    	}
     
    }
     
    class B extends A
    {
    	public final int b;
     
    	public B(int a, int b)
    	{
    		super(a);
    		this.b = b;
    	}
     
    }
     
    class C extends B
    {
    	// on ne peut pas appeler directement un constructeur de A, autrement B.b ne serait jamais initialisé
    }

  13. #13
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    Disons qu'à la différence de Java, C++ offre la liberté de le faire, au développeur de bien s'en servir. Il est vrai que plus de liberté engendre plus de possibilité de faire des erreurs.

    Moi je suis partisan de cette liberté, mais je comprend qu'on puisse ne pas l'être.

  14. #14
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Dans ce cas précis ces "libertés" cassent le principe d'encapsulation.

    Au niveau de la classe "B" tu ne peux pas définir si les classes filles auront accès ou pas au paramètres du constructeur du parent. Que se passe-t-il si tu veux utiliser une valeur spécifique dans "B" mais qu'une classe fille utilise directement une autre valeur ???


    a++

  15. #15
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    Tu pourrais illustrer ce que tu dis par un bout de code stp ? Je comprendrais mieux de quoi tu veux parler

  16. #16
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 586
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 586
    Par défaut
    Citation Envoyé par scheme Voir le message
    Disons qu'à la différence de Java, C++ offre la liberté de le faire, au développeur de bien s'en servir. Il est vrai que plus de liberté engendre plus de possibilité de faire des erreurs.

    Moi je suis partisan de cette liberté, mais je comprend qu'on puisse ne pas l'être.
    +1 sur ce que dit adiGuba sur le principe d'encapsulation.

    Mais de manière générale, Java fait très souvent le choix de conception de limiter les libertés du programmeur pour prévenir certaines erreurs qui peuvent être prévenues au compile-time. (Et d'autres ASAP au runtime.)

    C'est intrinsèque au langage, c'est un fait. C'est loin d'être limité à ce seul exemple.

    Citation Envoyé par scheme Voir le message
    Tu pourrais illustrer ce que tu dis par un bout de code stp ? Je comprendrais mieux de quoi tu veux parler
    SucreGlace l'a déjà fait au-dessus.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  17. #17
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Un exemple à la con : dans B je veux fixer certaines valeurs du parent :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    class B extends A {
    	public B() {
    		super(0.0 ENUM_VALUE);
    	}
    }
    Afin que toutes les classes filles utilisent ces valeurs.


    Comment ferais-tu cela en C++ si les classes filles peuvent appeler directement le constructeur du "grand parent" ?


    a++

  18. #18
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    Effectivement dans ce cas ce ne serait pas une bonne chose d'appeler directement le constructeur de A depuis C.

    Je ne dis pas qu'il faut le faire systématiquement, mais que c'est bien pratique d'en avoir la possibilité, dans le cas que j'ai cité tout au début du topic par exemple.

    A l'usage, ça évite de devoir recopier le constructeur plusieurs fois, de faire des super() partout, et de passer en copie les collections plusieurs fois au lieu d'une seule.

  19. #19
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 586
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 586
    Par défaut
    et de passer en copie les collections plusieurs fois au lieu d'une seule.
    À moins que tu le demandes en le programmant explicitement, les collections (et tous les objets) ne seront pas copiées, mais passées telles que.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  20. #20
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 206
    Par défaut
    C'est bon à savoir

    Et pour les objets, ils sont passés par copie ou par référence ?

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Héritage et appel des constructeurs parents
    Par Antoine_935 dans le forum Débuter
    Réponses: 7
    Dernier message: 13/05/2009, 19h03
  2. Réponses: 4
    Dernier message: 02/01/2009, 11h33
  3. Réponses: 2
    Dernier message: 25/08/2006, 22h53
  4. Réponses: 2
    Dernier message: 03/06/2006, 13h25
  5. [héritage privé] appel du constructeur de base
    Par PINGOUIN_GEANT dans le forum C++
    Réponses: 4
    Dernier message: 19/10/2004, 15h05

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