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 :

[generics] type de retour générique parent d'une classe donnée


Sujet :

Langage Java

  1. #1
    Membre éprouvé
    Avatar de Sivrît
    Profil pro
    Inscrit en
    Février 2006
    Messages
    953
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 953
    Points : 1 249
    Points
    1 249
    Par défaut [generics] type de retour générique parent d'une classe donnée
    'lut,

    Je coince sur une utilisation de la généricité. J'ai une classe MaClasse qui étend MaSuperClasse. Des classes tierces en contiennent des brouettes et ont des méthodes du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public Collection<MaClasse> putAllIn(Collection<MaClasse> c);
    Cette méthode retourne les objets MaClasse contenus en les plaçant dans la collection passée en paramètre (pour éviter d'instancier des tonnes de collections).

    Seulement dans certains cas on aimerait mettre les MaClasse dans une Collection<MaSuperClasse> sans faire deux méthodes différentes. Avec la généricité j'aurais voulu faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public <T super MaClasse> Collection<T> putAllIn(Collection<T> c);
    mais ça ne marche pas. 'super' semble ne passer qu'avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public Collection<? super MaClasse> putAllIn(Collection<? super MaClasse> c);
    mais le type de retour est inutilisable car il n'y a pas de corresondance avec le type du paramètre.

    Est-ce que quelqu'un aurait une solution ou, comme je commence à le penser, c'est impossible ?

    Merci.

  2. #2
    Membre expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Points : 3 080
    Points
    3 080
    Par défaut
    C'est normal, comment veux-tu que le compilateur détermine le supertype que tu veux utiliser...?

    Pourquoi ta méthode prend en paramètre une collection et en revoie une autre...?
    Moi j'aurais fait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    public <T> void putInAll(Collection<T> source, Collection<? super T> cible) {
        for(T t : source)
            cible.add(t);
    }
    Tu ne peux pas renvoyer "la même" collection, car Collection<MaClasse> n'étend pas Collection<MaSuperClasse>...

  3. #3
    Membre éprouvé
    Avatar de Sivrît
    Profil pro
    Inscrit en
    Février 2006
    Messages
    953
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 953
    Points : 1 249
    Points
    1 249
    Par défaut
    Effectivement ce genre de définition laisse plusieurs types possibles pour un même appel. Mais le compilateur devrait pouvoir se débrouiller en utilisant le type exact du paramètre et en n'autorisant que les ajouts...

    Sinon ne pas retourner la liste j'aurais dû y penser. En fait retourner la liste permet aux flemmards de passer null en paramètre quand on n'a pas de liste à remplir sous la main (Et en instanciant une ArrayList en interne on a plus facilement une idée de la taille à prévoir)... et je connais un flemmard qui n'avait pas envie de devoir réécrire tous les appels Je vais partir là-dessus.

    N'empèche, je ne suis pas certain de voir ce qui empèche le compilateur d'identifier T à MaSuperClasse dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    putAllIn(new Collection<MaSuperClasse>())
    même si Object serait aussi une solution. En limitant l'utilisation de la collection à des ajouts d'éléments dérivant MaSuperClasse je ne voit pas ce qui bloque.

  4. #4
    Membre expert
    Avatar de ®om
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 815
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 815
    Points : 3 080
    Points
    3 080
    Par défaut
    Bah, dans ce cas tu as une Collection<MaSuperClasse>, pourquoi veux-tu un autre type en paramètre?

  5. #5
    Membre confirmé Avatar de spekal
    Inscrit en
    Mai 2005
    Messages
    502
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 502
    Points : 510
    Points
    510
    Par défaut
    Moi aussi j'écrirais quelque chose comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
      public <T extends MaSuperClasse> Collection<MaSuperClasse> putAllIn(Collection<T> collec)
    Au fait oui, super ne peut pas s'utiliser avec un type paramètre, seulement avec une wildcard.

  6. #6
    Membre éprouvé
    Avatar de Sivrît
    Profil pro
    Inscrit en
    Février 2006
    Messages
    953
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Février 2006
    Messages : 953
    Points : 1 249
    Points
    1 249
    Par défaut
    Citation Envoyé par spekal
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      public <T extends MaSuperClasse> Collection<MaSuperClasse> putAllIn(Collection<T> collec)
    Le problème est que dans ce cas on ne peut plus ajouter que des T dans la collection. Si on a déjà des objets d'un type donné, la méthode ne pourra pas les ajouter. Il faudrait donc rendre toute la classe générique ce qui n'est pas nécessairement jouable.

    Donc ce sera la version de ®om... ou alors la question ne se posera plus car je réfléchie très fort à un refactoring de mon plat de nouilles

    Merci.

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

Discussions similaires

  1. Réponses: 15
    Dernier message: 01/03/2015, 13h16
  2. Réponses: 0
    Dernier message: 19/07/2014, 19h35
  3. Réponses: 0
    Dernier message: 24/05/2011, 11h05
  4. Réponses: 21
    Dernier message: 14/01/2010, 12h50
  5. Réponses: 7
    Dernier message: 22/02/2007, 16h57

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