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

Affichage des résultats du sondage: Êtes-vous pour ou contre cette proposition ?

Votants
349. Vous ne pouvez pas participer à ce sondage.
  • Pour la proposition 1

    102 29,23%
  • Pour la proposition 2

    10 2,87%
  • Pour la proposition 3

    11 3,15%
  • Contre

    226 64,76%
Langage Java Discussion :

JDK 7: Proposition 13 : Accès aisé aux propriétés [Débat]


Sujet :

Langage Java

  1. #21
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Par défaut
    Oui pour le '#'. L'utilisation du '.' porte trop a confusion avec les membres publiques de la classe et les programmeurs venant du C/C++ trouveront bizarre l'usage du '=>'.
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  2. #22
    Membre régulier
    Inscrit en
    Décembre 2007
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 46
    Points : 86
    Points
    86
    Par défaut
    pour la 1 ou autre.
    en tous cas pas la 2 qui me donne l'impression de déplacer ou d'affecter un objet vers un autre. je suis pas programmeur C et quand je vois a=>b, je comprends "a va vers b". pareil pour d'autres langages qui introduisent les ->

    ni la 3 qui est gros et voyant comme tout. le point est la norme de séparation entre classe et membres dans java. introduire autre chose ne ferait que casser la norme.

  3. #23
    Membre éclairé

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2002
    Messages
    346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2002
    Messages : 346
    Points : 737
    Points
    737
    Par défaut
    Contre.

    On utilise un attribut public si on veut faire ça.
    Pour moi, ça viole le principe du JavaBean

  4. #24
    Membre confirmé Avatar de heid
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    388
    Détails du profil
    Informations personnelles :
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Mai 2002
    Messages : 388
    Points : 597
    Points
    597
    Par défaut
    Citation Envoyé par woodwai Voir le message
    Contre.

    On utilise un attribut public si on veut faire ça.
    Pour moi, ça viole le principe du JavaBean
    Il faut bien comprendre que ce n'est qu'une astuce du compilateur et que le code final est le même. Vous appellerez le getter/setter de façon transparente c'est tout. Le JavaBean peut donc retirer sa plainte pour viol

  5. #25
    Rédacteur
    Avatar de benwit
    Profil pro
    dev
    Inscrit en
    Septembre 2004
    Messages
    1 676
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : dev

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 676
    Points : 4 265
    Points
    4 265
    Par défaut
    Contre aussi.

    Tout le monde savait que c'était impossible. Il est venu un imbécile qui ne le savait pas et qui l'a fait. Marcel PAGNOL
    On ne savait pas que c'était impossible, alors on l'a fait. John Fitzgerald KENNEDY.
    L'inexpérience est ce qui permet à la jeunesse d'accomplir ce que la vieillesse sait impossible. Paul (Tristant) BERNARD
    La meilleure façon de prédire l'avenir, c'est de l'inventer.

  6. #26
    Rédacteur
    Avatar de romaintaz
    Homme Profil pro
    Java craftsman
    Inscrit en
    Juillet 2005
    Messages
    3 790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Java craftsman
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2005
    Messages : 3 790
    Points : 7 275
    Points
    7 275
    Par défaut
    J'ai voté pour la proposition #1, mais après réflexion, j'aurais plutôt dû voter contre
    Nous sommes tous semblables, alors acceptons nos différences !
    --------------------------------------------------------------
    Liens : Blog | Page DVP | Twitter
    Articles : Hudson | Sonar | Outils de builds Java Maven 3 | Play! 1 | TeamCity| CitConf 2009
    Critiques : Apache Maven

  7. #27
    Membre confirmé Avatar de JoloKossovar
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    532
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 532
    Points : 576
    Points
    576
    Par défaut
    Clairement contre les 3 et au final encore plus contre le '.'.
    Ca ne ferai que rendre le code plus confu, et vive les get/set !

  8. #28
    Membre éclairé
    Avatar de Floréal
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    456
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 456
    Points : 849
    Points
    849
    Par défaut
    Cela permet il, comme en .Net d'écrire du code que peut impliquer l'accès à de telle propriété?
    exemple bidon, pour compter les accès:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    class Toto
    {
      private int compteur;
      private String uneChaine_;
      public property String uneChaine {
        get { compteur++; return uneChaine_; }
        set { compteur++; uneChaine_ = uneChaine; }
      }
    }
    Ancien membre du projet "Le Dernier Âge".

  9. #29
    Membre habitué Avatar de ludosoft
    Homme Profil pro
    Chef de projet technique
    Inscrit en
    Juillet 2002
    Messages
    99
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Chef de projet technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2002
    Messages : 99
    Points : 136
    Points
    136
    Par défaut
    Je préfère la 1 car ça ressemble à ce que j'ai connu quand je développais des composants graphiques avec C++ Builder. Je pouvais utiliser les propriétés directement comme une variable (comme dans la proposition 1 quoi).
    Et un d'plus en moins !

  10. #30
    Membre habitué
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    132
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2007
    Messages : 132
    Points : 170
    Points
    170
    Par défaut
    Contre

    si le champ est privé je ne vois pas pourquoi on devrait pouvoir y avoir accés grace ou point ou autre.

    Ajouter une syntaxe complexifierai de facon inutile JAVA.

    De plus le "." ne nous indique pas si on peut ou pas modifier la valeur alors qu'avec un set ou un get ...

    Surtout que de nos jours avec les IDE et l'autocompletion...

  11. #31
    Membre confirmé Avatar de heid
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    388
    Détails du profil
    Informations personnelles :
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Mai 2002
    Messages : 388
    Points : 597
    Points
    597
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    maval.x = maval1.y+maval2.z;
     
    maval.setX(maval1.getY() + maval2.getZ());
    Quel est le plus lisible selon vous?

  12. #32
    Expert éminent sénior Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 562
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 562
    Points : 15 490
    Points
    15 490
    Par défaut
    Je suis pour l'acces simplifié au propriétés et j'ai voté pour le "#" car je pense qu'il faut absolument faire la différence avec un attribut classique. Ceci dit c'est vrai qu'il fait un peu trop mastodonte.

    Le problème du "=>" c'est qu'il implique une notion de déplacement ou de conséquence. en plus ca rapele le "->" qui a une signification particlière en C++.

    Je pense que le "°" aurait été un meilleur choix mais vu que ce n'est pas un caractère ascii standard, ca n'irait pas. Le "`" serait aussi un bon choix vu que c'est un carractère ascii standard.

  13. #33
    Membre éclairé Avatar de bassim
    Homme Profil pro
    Ingénieur Réseaux
    Inscrit en
    Février 2005
    Messages
    666
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur Réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2005
    Messages : 666
    Points : 695
    Points
    695
    Par défaut
    Citation Envoyé par Uther Voir le message
    Je pense que le "°" aurait été un meilleur choix mais vu que ce n'est pas un caractère ascii standard, ca n'irait pas. Le "`" serait aussi un bon choix vu que c'est un carractère ascii standard.
    je propose le @
    Where is my mind

  14. #34
    Membre régulier
    Inscrit en
    Décembre 2007
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 46
    Points : 86
    Points
    86
    Par défaut
    Citation Envoyé par bassim Voir le message
    je propose le @
    et pourquoi pas ‡ ou ¥ ou encore þ ou encore ‰

  15. #35
    Membre éprouvé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 064
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 064
    Points : 1 053
    Points
    1 053
    Par défaut
    Contre, autant c'est utile en C#, autant ça l'est parceque cette fonctionnalité est incluse au langage depuis le début. Je suis sur que ça dénaturera la syntaxe tot ou tard.

  16. #36
    Expert éminent sénior Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 562
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 562
    Points : 15 490
    Points
    15 490
    Par défaut
    Citation Envoyé par bassim Voir le message
    je propose le @
    Citation Envoyé par gokud-o-matic Voir le message
    et pourquoi pas ‡ ou ¥ ou encore þ ou encore ‰
    Je vois pas en quoi "`" serait plus idot que "#", d'autant que c'est un caractère ASCII standard. L'aspect qu'il ne soit pas courrament utilisé fait justement que ce n'est pas genant.
    Le @ a bien déjà été ajouté pour les annotations.

  17. #37
    Expert éminent
    Avatar de djo.mos
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    4 666
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 666
    Points : 7 679
    Points
    7 679
    Par défaut
    Contre.
    J'ai déjà voté contre le concept de property, donc ce la va de soi que je suis aussi contre l'accès simple aux properties

  18. #38
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    156
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 156
    Points : 191
    Points
    191
    Par défaut
    Moi je suis assez pour.
    En fait le langage Java a imposé une regle de conception assez hideuse.

    Alors oui aujourd'hui tous nos IDE favoris générent des getters/setter inutiles.
    Sincèrement dans la grande majorité des cas le getter/setter se contente de renvoyer de manière stricte l'attribut sous jacent.
    A l'occasion le getter/setter se permet un contrôle une transformation.
    C'est très flagrant pour les "DataObjects".
    Moi je suis pour l'ajout de ce sucre syntaxique.

  19. #39
    Rédacteur
    Avatar de bulbo
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2004
    Messages
    1 259
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Février 2004
    Messages : 1 259
    Points : 1 937
    Points
    1 937
    Par défaut
    Citation Envoyé par phantomass Voir le message
    Moi je suis assez pour.
    En fait le langage Java a imposé une regle de conception assez hideuse.

    Alors oui aujourd'hui tous nos IDE favoris générent des getters/setter inutiles.
    Sincèrement dans la grande majorité des cas le getter/setter se contente de renvoyer de manière stricte l'attribut sous jacent.
    A l'occasion le getter/setter se permet un contrôle une transformation.
    C'est très flagrant pour les "DataObjects".
    Moi je suis pour l'ajout de ce sucre syntaxique.
    Amusant on m'a appris cette règle de conception hideuse avec un autre langage que java.. et avant que java existe même (qui a dit oh le vieux ? )

    Explication de la dites règle que tu semble méconnaitre:

    Si tu accèdes directement a un attribut d'une classe et que demain pour une raison XY ou Z tu as une nouvelle contrainte a vérifiée avant d'accéder a l'objet en lecture et ou en écriture tu te retrouves a réécrire tout tes accès pour utiliser le couple infernal setter/getter, pas top au niveau de la maintenance de ton code tu en conviendras..
    Le pire que tu pourrais faire étant de laisser ton champ public et de juste ajouter les getter/setter en sus, résultat si tu oublies de changer un accès ou si quelqu'un décide d'accéder directement a l'attribut tu as un gros problème..

    Bulbo
    [Java] [NetBeans] [CVS]
    La FAQ Java
    Merci de ne pas me poser de questions techniques par MP.

  20. #40
    Membre éprouvé
    Avatar de yolepro
    Profil pro
    Architecte de système d'information
    Inscrit en
    Mai 2002
    Messages
    918
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Mai 2002
    Messages : 918
    Points : 1 144
    Points
    1 144
    Par défaut
    Et dans le cas d'une implémentation comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    public String prenom;
     
    public String getPrenom(){
      return prenom;
    }
     
    public void setPrenom(String prenom) {
      this.prenom = prenom;
    }
    il faudrait choisir quoi avec la solution 1 ?

    Autant enlever la complexité des getter setter grâce à des annotations c'est une bonne idée (cela respecte tout de même les spec des javabean), autant modifier la manière d'appeler ces accesseurs, ca déforme énormenent la manière de penser et cela devient vraiment confus.
    Etre c'est etre relatif.

Discussions similaires

  1. Zone de liste, accès aux propriétés par code
    Par AndréPe dans le forum VBA Access
    Réponses: 3
    Dernier message: 10/02/2007, 10h41
  2. Réponses: 4
    Dernier message: 22/12/2005, 11h43
  3. [Problème] Accès aux propriétés de listes nommées avec []
    Par VincentL dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 05/10/2005, 16h13
  4. Accès aux propriétés ScrollBar d'un composant TMemo
    Par fausto dans le forum C++Builder
    Réponses: 2
    Dernier message: 10/10/2003, 11h08
  5. Accés rapide aux propriétés d'un Objet
    Par Alacazam dans le forum C++Builder
    Réponses: 4
    Dernier message: 28/11/2002, 21h56

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