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

Java Discussion :

La généricité des méthodes en java


Sujet :

Java

  1. #1
    Membre habitué
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2010
    Messages
    212
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2010
    Messages : 212
    Points : 184
    Points
    184
    Par défaut La généricité des méthodes en java
    Salut,
    soit le code suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    static <T> void fromArrayToCollection(T[] a, Collection<T> c) {
        for (T o : a) {
            c.add(o); // Correct
        }
    }
    ce code compile normalement et aucune erreur n'est signalée. Mais quand je supprime le generic qui se trouve après le modificateur static, une erreur de compilation est signalée:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    error: cannot find symbol
        static  void fromArrayToCollection(T[] a, Collection<T> c) {
      symbol:   class T
      location: class Main
     
    error: cannot find symbol
        for (T o : a) {
      symbol:   class T
      location: class Main
    3 errors
    voici quelques questions que je me posent:
    1. quand je déclare une méthode generic, est ce que le generic après le modificateur de la méthode est obligatoire. si c'est le cas pourquoi?
    2. pour quoi que le compilateur ne peut pas déduire le generic depuis la signature de la méthode.

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Le <T> avant le type est la déclaration du paramètre. Elle est indispensable : il n'y a pas de déclaration implicite en Java. S'il y avait déduction sans déclaration, ça voudrait dire qu'on pourrait taper n'importe quoi et que dans ce cas Java considérerait qu'au lieu d'une erreur on voudrait définir un type paramétré. En plus, quelque part <T> est un cas particulier, car on pourrait écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public static <T extends Number&Comparable<T>> T max(T value1, T value2, @SuppressWarnings("unchecked") T...others) {
       T max = value1.compareTo(value2)>=0?value1:value2;
       for(T other : others) {
           max = other.compareTo(max)>=0?other:max;
       }
       return max;
    }

  3. #3
    Modérateur

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

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 568
    Points : 21 636
    Points
    21 636
    Par défaut
    Je dirais de manière simple :

    Citation Envoyé par win_ubuntu Voir le message
    pour quoi que le compilateur ne peut pas déduire le generic depuis la signature de la méthode.
    Il n'y a aucune raison que T soit un type générique. Ça pourrait être une classe qui porte un très mauvais nom.

  4. #4
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par win_ubuntu Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    static <T> void fromArrayToCollection(T[] a, Collection<T> c) {
        for (T o : a) {
            c.add(o); // Correct
        }
    }
    J'ai du mal à comprendre cette syntaxe, soit on renvoie un type paramétré "<T>", soit on ne renvoie rien "void".
    Là, on pourrait comprendre que le "rien" est typé...
    Le pire, c'est que le compilateur ne renvoie pas d'erreur, personnellement, je trouve cette syntaxe aberrante
    Si quelqu'un pouvait m'expliquer en passant, ce serait cool

  5. #5
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Si le void pouvait être paramétré, il <T> serait après : void<T>. Le fait que le <T> soit avant le type de retour indique qu'il s'agit d'une déclaration de paramètre concernant la méthode elle-même.

    On aurait pu écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    static <T> Collection<T> fromArrayToCollection(T[] a) {
    		return Arrays.asList(a);
    }

  6. #6
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    Citation Envoyé par OButterlin Voir le message
    J'ai du mal à comprendre cette syntaxe, soit on renvoie un type paramétré "<T>", soit on ne renvoie rien "void".
    Non, la déclaration du type paramétré n'a rien à voir avec le type retourné. Le mettre au début de la fonction permet d'indiquer qu'on va utiliser un type paramétré qu'on appelera T. Et comme T peut etre utilisé en parametre de la fonction comme en tant que type de retour, c'est plutot pas mal à mon avis de le mettre au début...

  7. #7
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    Effectivement, on aurait dû avoir void<T>, ça m'a tellement perturbé que je n'ai même pas fait gaffe... désolé...

Discussions similaires

  1. Traduire des méthodes @PostConstruct de Java EE vers Spring
    Par bruneltouopi dans le forum Spring
    Réponses: 1
    Dernier message: 26/01/2015, 16h56
  2. Simplexe méthodes des pénalités en java
    Par cixion dans le forum Débuter avec Java
    Réponses: 0
    Dernier message: 12/05/2011, 23h26
  3. Réponses: 9
    Dernier message: 18/06/2010, 11h28
  4. Appeler des méthodes Java dans javascript
    Par Kyo-AzN dans le forum Langage
    Réponses: 4
    Dernier message: 22/10/2008, 21h19
  5. JAVA - Passer des Objects à des méthodes
    Par canou94 dans le forum CORBA
    Réponses: 2
    Dernier message: 15/11/2005, 23h39

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