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 :

[Java 8+] A propos des 'default' methodes


Sujet :

Langage Java

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2013
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2013
    Messages : 31
    Points : 37
    Points
    37
    Par défaut [Java 8+] A propos des 'default' methodes
    Bonjour,

    J'aimerais soulever un point concernant les methodes par default dans une interface qui me semble très peu voir pas tout tout traité.

    Dans tous les exemples que j'ai trouvé sur le sujet, on explique la chose avec des trucs du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    public interface foo
    {
        default void foo()
        {
            System.out.println("foo default");
        }
    }
     
    ...
    C'est bien beau mais je trouve que c'est un peu limite même si ca n'enleve rien à la bonne volonté de redacteur de l'aide :p

    Pour les methodes par default que j'ai ecrites, je suis obligé de passer en parametre l'objet qui appel cette methode, genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    public class c
    {
        ...
     
        methode(...)
        {
            ...
            default_interface_methode(this, ...);
            ...    
        }
    }
    Dans la pratique ca pose pas de probleme evidement, mais conceptuellement, des methodes d'un objet qui ont besoin de prendre en parametre ce dit objet c'est pas terrible, non ?

    Donc, je voudrait savoir si il y a une maniere plus propre de faire.

    Si non, est que vous pensez comme moi, qu'un mot cle equivalent de 'this' pour les methodes par default serait une bonne choses à voir implementé ?

    Voila, c'est un petit detail qui m'a un peu interpellé .

  2. #2
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    Je ne comprend pas du tout ce que tu veux dire par là...

    Tu aurais un code minimal qui compile ?


    a++

  3. #3
    Membre chevronné
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Points : 1 855
    Points
    1 855
    Par défaut
    ceci te conviendrait-il mieux comme exemple ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    public interface ProduitTaxable {
        double getPrixHT() ;
        /**
        * sous forme 1.196 par exemple
        */
        double getTauxTVA() ;
        default double getPrixTTC(){
            return this.getPrixHT() * this.getTauxTVA() ;
        }
    }
    J'ai des principes: je peux toujours trouver une bonne raison pour les contredire .... mais j'ai des principes!
    (mon excellent bouquin sur Java : https://eska-publishing.com/fr/livre...822407076.html)

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2013
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2013
    Messages : 31
    Points : 37
    Points
    37
    Par défaut
    voila mon cas concret :

    J'ai deux interfaces "Master" et "Slave" qui fonctionne sur le principe du pattern observer si j'ai bien compris le truc xD :

    slave :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    public interface Slave extends Runnable
    {
        void setMaster(Master m);
     
        ...
    }
    master :
    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
     
    public interface Master
    {
        List<Slave> getSlaves();
     
        void addSlave(slave s);
     
        ...
     
        void treatSlaveData(Slave s);
     
     
        default void workAll(Master m)
        {
             for (Slave s : m.getSlaves())
             {
                    s.run();
                    m.treatslaveData(s);
             }
        }
    }

    voila donc quand j’appelle cette methode ca donne :
    C'est comme ci je devait ecrire :

    'm.getName(m);'

    au lieu de

    'm.getName()

    je voudrait pouvoir l'utiliser comme ça : m.workAll(); (sans devoir heriter d'un class specifique, c bien le but des interfaces ^^)

    voila j'espere que c plus clair.


    edit : sinon pour l’exemple merci mais ces champ que tu utilise avec this sont quand même statiques, non?

  5. #5
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Ben... tu peux utiliser this dans le corps d'une méthode par défaut.
    Ce this correspondra bien sûr à l'instance réel sur laquelle sera appelée la méthode :

    Donc dans ton cas il suffit de faire ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        default void workAll()
        {
             for (Slave s : this.getSlaves())
             {
                    s.run();
                    this.treatslaveData(s);
             }
        }

    a++

  6. #6
    Modérateur

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

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 551
    Points : 21 607
    Points
    21 607
    Par défaut
    Ma question va sembler stupide mais je veux arrêter d'être stupide et apprendre :
    pourquoi pas simplement ce qui suit ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    default void workAll()
    {
      for (Slave s : getSlaves())
      {
        s.run();
        treatslaveData(s);
      }
    }
    Moi je veux bien qu'on mette this, même c'est peut-être plus clair ou je sais pas.

    Mais en revenant au départ, quand on savait pas qu'on pouvait mettre this, qu'est-ce qui obligeait à mettre this ou m ou quoi que ce soit ?
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par thelvin Voir le message
    Ma question va sembler stupide mais je veux arrêter d'être stupide et apprendre :
    pourquoi pas simplement ce qui suit ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    default void workAll()
    {
      for (Slave s : getSlaves())
      {
        s.run();
        treatslaveData(s);
      }
    }
    Moi je veux bien qu'on mette this, même c'est peut-être plus clair ou je sais pas.
    C'est la même chose : getSlaves() ou this.getSlaves() cela revient au même et cela reste au choix de chacun...

    Les méthodes par défaut sont des méthodes d'instances, et le this est implicite s'il n'est pas précisé.



    Citation Envoyé par thelvin Voir le message
    Mais en revenant au départ, quand on savait pas qu'on pouvait mettre this, qu'est-ce qui obligeait à mettre this ou m ou quoi que ce soit ?
    Je pense qu'0xNoob a dû faire du C#, qui propose un système de méthode d'extension qui fournit à peu près la même chose en apparence, malgré une implémentation et des fonctionnalités différente...


    a++

  8. #8
    Modérateur

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

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 551
    Points : 21 607
    Points
    21 607
    Par défaut
    Comme d'habitude, tu rocks
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

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

Discussions similaires

  1. [Java 8] default method: pas de final possible
    Par professeur shadoko dans le forum Langage
    Réponses: 19
    Dernier message: 09/09/2014, 10h26
  2. A propos des packages Java
    Par theAlex dans le forum Langage
    Réponses: 4
    Dernier message: 04/09/2007, 15h41
  3. Une question à propos des thread
    Par tscoops dans le forum C++Builder
    Réponses: 4
    Dernier message: 07/11/2003, 14h03
  4. A propos des 'File management Functions' de Windows
    Par znaidi dans le forum Windows
    Réponses: 3
    Dernier message: 01/04/2003, 16h01
  5. A propos des modèles d'objet (avec sources)
    Par DevX dans le forum C++Builder
    Réponses: 14
    Dernier message: 01/12/2002, 12h22

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