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 :

mettre le "this." ou pas


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2003
    Messages : 8
    Par défaut mettre le "this." ou pas
    Hello,

    Une petite question qui me trotte dans la tête...

    Ca concerne l'utilisation du "this." même quand il n'est pas nécessaire.

    Par exemple, je suis dans une méthode de ma classe et je veux appeler un getter.
    Est-ce que je mets "getMonAttribut()" ou "this.getMonAttribut()" ?!?

    Et surtout, et c'est nettement plus intéressant, POURQUOI vaut-il mieux utiliser l'un plutôt que l'autre ?

    Merci d'avance.

    ps : j'imagine que la question a déjà été posée... mais quand je cherche "this", ça me retourne systématiquement 0 résultat !

  2. #2
    Membre émérite Avatar de yann2
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2004
    Messages
    897
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2004
    Messages : 897
    Par défaut
    Bonjour

    Je le mets systèmatiquement. Pourquoi ? Parce que ça permet, en seul coup d'oeil, de savoir si la méthode est de classe ou d'instance, si une variable est locale ou est une variable d'instance etc.
    Ceci implique de mettre systèmatiquement le nom de la classe lorsque l'on utilise un membre de classe.

    yann

  3. #3
    Expert confirmé
    Avatar de Baptiste Wicht
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2005
    Messages
    7 431
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Suisse

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2005
    Messages : 7 431
    Par défaut
    Non, tu n'es pas obligé de le mettre, car le compilo va automatiquement le rajouter derrière toi

    Il y a un cas ou tu es obligé de le mettre, c'est quand tu as une variable d'instance avec le nom qu'une variable locale.

    Si tu fais comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public void setX(int x){
    x=x;
    }
    Tu auras pas d'erreur, mais ça sert à rien. Il faut attribuer la valeur locale à la valeur globale :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public void setX(int x){
    this.x=x;
    }

  4. #4
    Membre émérite
    Avatar de sironimo
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    669
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Mai 2004
    Messages : 669

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2003
    Messages : 8
    Par défaut
    ok, ok... je sais très bien que je ne suis pas obligé de le mettre, mais que dans certains cas il faut quand même le faire.

    pour être plus précis, j'ai pour habitude de TOUJOURS le mettre (obligatoire ou non), et un collègue vient de me dire que "non, c'est pas bien, faut pas le mettre systèmatiquement", sans me donner bcp plus d'explications.

    bref, quels arguments y'a-t-il pour dire qu'il ne faut pas le mettre quand ce n'est pas nécessaire ?

  6. #6
    Membre Expert Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Par défaut
    Si tu utilises le this c'est plus sur je trouve. Car si jamais tu ne fais pas très attention et que tu appelles un parametre de methode de la meme facon ton code ne sera pas atteint.

    Alors que sans le this tu peux avoir des surprises.

  7. #7
    Membre émérite
    Profil pro
    Architecte technique
    Inscrit en
    Mars 2002
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Par défaut
    Il n'y a aucun argument autre pour le mettre ou non.

    Moi je ne le mets jamais sauf dans les cas ou il y a collision entre un paramétre de méthode et une variable locale, ou entre un attribut d'instance et un variable locale.

    Pour moi ça alourdi le code d'autant plus, comme les gens qui mettent this devant l'appel à une méthode d'instance dans une autre méthode de la même instance, je trouve ça trop lourd.

    De plus eclipse averti le programmeur en cas de collision de nom, donc ce n'est asboluement pas indispensable.

    A+

  8. #8
    Membre chevronné
    Homme Profil pro
    Développeur Java
    Inscrit en
    Avril 2004
    Messages
    265
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Avril 2004
    Messages : 265
    Par défaut
    Oui je pense pas qu'il n'y est vraiment d'argument pour ou contre le mettre, par contre je pense que quand on travail à plusieurs c'edst pas mal de ce mettre d'accord histoire que les sources restent cohérentes.

  9. #9
    Membre émérite
    Profil pro
    Architecte technique
    Inscrit en
    Mars 2002
    Messages
    966
    Détails du profil
    Informations personnelles :
    Âge : 52
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Mars 2002
    Messages : 966
    Par défaut
    Tout à fait d'accord, mais pour moi le this est superflu et rend le code d'autant moins lisible...

    A+

  10. #10
    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
    Citation Envoyé par fabaroulettes
    bref, quels arguments y'a-t-il pour dire qu'il ne faut pas le mettre quand ce n'est pas nécessaire ?
    Aucun. C'est juste une préférence ou l'adoption d'une règle de codage, mais cela donnera exactement la même chose à la compilation...


    Et si tu veux une preuve, regarde ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    public class Main {
     
    	private String attr;
     
    	public void method() {
    		System.out.println( attr );
    		System.out.println( this.attr );
     
    	}
     
    }
    Si tu le compiles :
    Puis que tu désassemble son bytecode :
    Tu verra que tu obtiens exactement la même chose :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    public void method();
      Code:
     
       0:   getstatic       #2; //Field java/lang/System.out:Ljava/io/PrintStream;
       3:   aload_0
       4:   getfield        #3; //Field attr:Ljava/lang/String;
       7:   invokevirtual   #4; //Method java/io/PrintStream.println:(Ljava/lang/String;)V
     
       10:  getstatic       #2; //Field java/lang/System.out:Ljava/io/PrintStream;
       13:  aload_0
       14:  getfield        #3; //Field attr:Ljava/lang/String;
       17:  invokevirtual   #4; //Method java/io/PrintStream.println:(Ljava/lang/String;)V
     
       20:  return

    a++

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


    Citation Envoyé par fabaroulettes
    Et surtout, et c'est nettement plus intéressant, POURQUOI vaut-il mieux utiliser l'un plutôt que l'autre ?
    Si on ignore le cas où il est obligatoire (c'est à dire pour différencier un attribut d'instance d'une variable locale du même nom), il n'y a aucune différence entre les deux cas (avec ou sans this). Donc c'est principalement une question de lisibilité et de préférence personnelle...

    a++

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