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

avec Java Discussion :

Héritage et méthode privée


Sujet :

avec Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Points : 10
    Points
    10
    Par défaut Héritage et méthode privée
    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
    class A {
      A() {
        System.out.println("constructeur de A") ;
        qqChose() ;
      }
      private void qqChose() {
        System.out.println("appel de qqChose de A") ;
      }
    }
    class B extends A {
      B() {
        System.out.println("constructeur de B") ;
      }
      void qqChose() {
        System.out.println("appel de qqChose de B") ;
      }
    }
    public class Herit06 {
      public static void main(String [] args) {
        B b = new B() ;
      }
    }
    Affichage :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    constructeur de A
    appel de qqChose de A
    constructeur de B
    Pourquoi à l'exécution il n'emploie pas la méthode qqChose() de la classe dérivée B, parce que la méthode dans la classe A est privée me direz-vous. C'est justement là que je coince. C'est une question d'examen à laquelle je n'ai pas su répondre. Merci à ceux qui pourront éclairer mes lanternes.

  2. #2
    Membre extrêmement actif Avatar de jojodu31
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    875
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2008
    Messages : 875
    Points : 814
    Points
    814
    Par défaut
    es tu sur que ce code est correct ?
    ton constructeur de B ne fai rien... pas d appel super() ni rien... il doit y avoir une erreur

  3. #3
    Membre régulier
    Inscrit en
    Juin 2008
    Messages
    127
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 127
    Points : 76
    Points
    76
    Par défaut
    Citation Envoyé par jojodu31 Voir le message
    ton constructeur de B ne fai rien... pas d appel super() ni rien... il doit y avoir une erreur
    Merci Jojodu, j'étais à deux doigts d'aller réviser mes cours sur l'héritage. ouf !

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Points : 10
    Points
    10
    Par défaut
    Le super() est implicite, là n'est pas le problème, le code est parfaitement correct compile et s'exécute.

  5. #5
    Membre extrêmement actif Avatar de jojodu31
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    875
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2008
    Messages : 875
    Points : 814
    Points
    814
    Par défaut
    quand tu es dans le constructeur de ta classe A, tu appele qqChose() qui est défini dans cette mêmeclasse A. Je ne vois pas pk l'appel serait la méthode qqchose de la classe B Cette méthode n'est pas abstraite, et bien défini donc aucune raison d'appeler celle de B

  6. #6
    Membre éprouvé
    Profil pro
    Développeur Back-End
    Inscrit en
    Avril 2003
    Messages
    782
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Avril 2003
    Messages : 782
    Points : 935
    Points
    935
    Par défaut
    Citation Envoyé par liox* Voir le message
    Le super() est implicite, là n'est pas le problème, le code est parfaitement correct compile et s'exécute.
    le super() est implicite si tu ne met rien (c'est a dire pas de constructeur dans la classe B) à partir du moment ou tu met un constructeur B() ce constructeur doit explicitement faire appelle au super (sinon il surcharge pas : il remplace)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
      B() {
        super();
        System.out.println("constructeur de B") ;
      }

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Points : 10
    Points
    10
    Par défaut
    Enlever le "private" de la méthode qqueChose() et vous constaterez qu'à ce moment là c'est la méthode qqueChose() de B qui est appelée.

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Points : 10
    Points
    10
    Par défaut
    à fnobb :

    Que tu mettes super() ou non ne change absoblument rien. Si tu ne mets rien, super() sera écrit dans le bytecode de toute façon.

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    132
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2007
    Messages : 132
    Points : 170
    Points
    170
    Par défaut
    Salut c'est un comportement qui me parait normal.

    Toutes méthodes, attributs qui est déclaré "private" n'est accessible que par la classe elle même

    Sinon on pourrait surcharger un méthode privée ==> elle ne serait plus trop privée

    Si on essaie de voir une explication la dedans c'est que, tout bêtement, lorsque la méthode est private, elle n'est pas virtuelle. D'ailleurs c'est une bonne habitude à prendre, dans un constructeur on ne doit appeler que des méthodes private ou finale.

    Vu que la méthode n'est pas virtuelle tu peux la surcharger sans incident sur la classe Mère et c'est pourquoi ça compile.

  10. #10
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2008
    Messages : 16
    Points : 10
    Points
    10
    Par défaut
    Citation Envoyé par elmor Voir le message
    Salut c'est un comportement qui me parait normal.

    Toutes méthodes, attributs qui est déclaré "private" n'est accessible que par la classe elle même

    Sinon on pourrait surcharger un méthode privée ==> elle ne serait plus trop privée
    Ben oui c'est très logique finalement, comment n'y ai-je pas songé ? . Grand merci à toi Elmor pour ses explications détaillées

Discussions similaires

  1. setTimeout avec une méthode privée
    Par Erakis dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 29/06/2006, 10h47
  2. Exceptions, héritage et méthodes virtuelles
    Par Nuwanda dans le forum C++
    Réponses: 13
    Dernier message: 23/05/2006, 12h06
  3. Méthodes privées: pratique courant en Python
    Par Thierry Chappuis dans le forum Général Python
    Réponses: 3
    Dernier message: 25/11/2005, 19h30
  4. Réponses: 8
    Dernier message: 04/06/2004, 09h13
  5. [Héritage] Redéfinition méthode
    Par petit-ourson dans le forum Langage
    Réponses: 9
    Dernier message: 06/05/2004, 16h06

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