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 :

[Générics] Surcharge methode invalide


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Rédacteur
    Avatar de MrDuChnok
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2002
    Messages
    2 112
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 112
    Par défaut [Générics] Surcharge methode invalide
    Bonjour,

    Je suis en train d'utiliser les JTables dans le cadre d'un de mes projets, et je suis donc amené à utiliser les TableModels.
    J'ai voulu créer mon propre TableModel en surchargeant AbstractTableModel pour qu'il n'accepte des objects que d'un type donné.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    public class monTableModel<T extends Object> extends AbstractTableModel
    Tout se passe bien jusqu'au moment de la méthode : setValueAt.
    Je pensais que écrire ceci suffirait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    public void setValueAt(T value, int row, int col);
    Mais là, il me sort :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Name clash: The method setValueAt(T, int, int) of type monTableModel<T> has the same erasure as setValueAt(Object, int, int) of type AbstractTableModel but does not override it
    Si je change le prototype de ma méthode, en remplaçant "T" par Object, ça fonctionne, mais bien sûr je perd un peu le coté "spécialisation" de mon TableModel.

    Comment puis-je faire pour résoudre ce problème ? C'est à dire pouvoir "spécialisé" ma méthode setValueAt.

    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
    Par défaut
    C'est normal dans la classe parente (AbstractTableModel / ou interface TableModel), la méthode est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    setValueAt(Object,int,int)
    Tu n'as pas le droit de changer les types des paramètres lors d'une surcharge.

    Le problème ici c'est que TableModel n'est pas générique, il aurait fallu qu'il soit générique à la base pour que tu puisses faire ce que tu veux faire... étendre AbstractTableModel<T>...

    Au passage ton "extends Object" ne sert à rien

  3. #3
    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,


    Ce n'est pas possible car le type T pourrait être différent de Object et donc potentiellement incompatible avec la définition de la méthode setValueAt() (même si dans ce cas précis cela pourrait fonctionner).

    Le plus simple serait de te créer une nouvelle méthode en remplacement de setValueAt(), par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    	public void setTypedValueAt(T aValue, int rowIndex, int columnIndex) {
    		// ton code ici
    	}
    Et dans setValueAt(), tu te contentes d'appeler cette nouvelle méthode :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	/**
             * @throws ClassCastException
             */
    	@SuppressWarnings("unchecked") // cast (T)
    	public final void setValueAt(Object aValue, int rowIndex, int columnIndex) {
    		this.setTypedValueAt((T)aValue, rowIndex, columnIndex);
    	}
    Tu peux mettre la méthode en final pour qu'elle ne soit plus redéfinie directement...



    Pour la méthode getValueAt() tu ne devrais pas avoir de problème car la covariance des types de retour te permet de modifier le type de retour dans certains cas : (tu as de la chance car le tutoriel est publié aujourd'hui même : La covariance des types retournés par les méthodes en Java 5).

    a++

  4. #4
    Rédacteur
    Avatar de MrDuChnok
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2002
    Messages
    2 112
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 112
    Par défaut
    Merci bien de vos explications claire et net. Ca rejoint l'idée que j'avais.

    Au passage ton "extends Object" ne sert à rien
    C'est ce que je pensais, mais par desespoir, je m'étais dit "on sait jamais, sur un malentendu..." ^^'

    J'avais opté pour ta solution adiGuba, mais ça laisse une petite "faille" si on passe un objet différent de T dans la méthode "setValueAt", c'était ça qui me dérangeais.

    Merci quand même d'avoir pris le temps et répondre et d'argumenter vos réponses.

  5. #5
    Rédacteur
    Avatar de CyberChouan
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    2 752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 752
    Par défaut
    Citation Envoyé par MrDuChnok
    J'avais opté pour ta solution adiGuba, mais ça laisse une petite "faille" si on passe un objet différent de T dans la méthode "setValueAt", c'était ça qui me dérangeais.
    Dans ce cas, tu peux vérifier le type de l'objet dans un test, et agir en fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(tonObjet instanceof T) { /* ok */ } else { /* pas ok */ }
    Avant de poster, pensez à regarder la FAQ, les tutoriaux, la Javadoc (de la JRE que vous utilisez) et à faire une recherche
    Je ne réponds pas aux questions techniques par MP: les forums sont faits pour ça
    Mes articles et tutoriaux & Mon blog informatique

  6. #6
    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
    Par défaut
    Citation Envoyé par CyberChouan
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(tonObjet instanceof T) { /* ok */ } else { /* pas ok */ }
    Non, tu n'as pas le droit au "instanceof T"...
    instanceof n'intervient qu'à l'exécution, le T n'est dispo qu'à la compilation...

  7. #7
    Rédacteur
    Avatar de CyberChouan
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    2 752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 752
    Par défaut
    Citation Envoyé par ®om
    Non, tu n'as pas le droit au "instanceof T"...
    instanceof n'intervient qu'à l'exécution, le T n'est dispo qu'à la compilation...
    Argh! Zut! Merci pour cette précision, je ne savais pas (C'est ça de travailler tous les jours sur du java 1.4. J'essaye de me tenir au courant des nouveautés mais je ne pratique pas assez le 5.0+ pour bien connaître )
    Avant de poster, pensez à regarder la FAQ, les tutoriaux, la Javadoc (de la JRE que vous utilisez) et à faire une recherche
    Je ne réponds pas aux questions techniques par MP: les forums sont faits pour ça
    Mes articles et tutoriaux & Mon blog informatique

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

Discussions similaires

  1. [2.x] Surcharge method findAll
    Par polyosh dans le forum Symfony
    Réponses: 1
    Dernier message: 27/07/2012, 18h35
  2. Surcharger methode d'une instance sans etendre sa classe
    Par looclooc dans le forum Débuter
    Réponses: 4
    Dernier message: 22/09/2009, 14h42
  3. Generic Vs Surchargement methode
    Par soony dans le forum Débuter avec Java
    Réponses: 2
    Dernier message: 07/04/2009, 20h14
  4. surcharge methode et instance de classe
    Par julien25 dans le forum C++
    Réponses: 6
    Dernier message: 13/03/2009, 20h20
  5. surcharge methode d'un attribut
    Par guiguizekid dans le forum Général Python
    Réponses: 1
    Dernier message: 12/12/2008, 18h38

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