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

Débats sur le développement - Le Best Of Discussion :

Qu'est-ce qu'un code "propre" selon vous ?


Sujet :

Débats sur le développement - Le Best Of

  1. #461
    Expert éminent
    Avatar de _skip
    Homme Profil pro
    Développeur d'applications
    Inscrit en
    Novembre 2005
    Messages
    2 898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur d'applications
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 898
    Points : 7 752
    Points
    7 752
    Par défaut
    Un code en polyester lavé en machine à 90° avec de la poudre à lessive certifiée qui ne tue pas les poissons une fois déversée dans la mer.
    Ah ? on parlait pas de ça ?

    Tout a été dit

    -Commenté mais pas paraphrasé
    -Efficace mais facile à comprendre

  2. #462
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    133
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 133
    Points : 149
    Points
    149
    Par défaut
    Un code propre est un code qui crée des bugs facile à débugger. Ca passe ?

  3. #463
    Membre éprouvé Avatar de I_believe_in_code
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    219
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 219
    Points : 1 043
    Points
    1 043
    Par défaut
    Un code propre est un code qu'on n'est jamais tenté de modifier.

  4. #464
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Citation Envoyé par ipingu Voir le message
    Un code propre est un code qui crée des bugs facile à débugger. Ca passe ?
    Idéalement un code propre serait exempt de bug
    Citation Envoyé par I_believe_in_code Voir le message
    Un code propre est un code qu'on n'est jamais tenté de modifier.
    Si tu remplace le terme "modifier" par "réécrire", je suis d'accord...

    Je pinaille sur le terme, mais une modification du code peut très bien survenir simplement parce que, le temps aidant, tu as eu l'occasion de te rendre compte de certaines faiblesses de conception et que tu as décidé (ou du) revoir une partie de celle-ci, alors qu'une réécriture sera plutôt due à l'impossibilité du lecteur de comprendre le raisonnement que l'auteur a pu suivre, rendant toute modification hasardeuse et potentiellement dangereuse

    Dans le premier cas, c'est un risque inhérent au cycle de développement, dans le second cas, c'est effectivement le signal qu'un code n'est sans doute "pas propre".
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  5. #465
    Membre expérimenté

    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    1 377
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2005
    Messages : 1 377
    Points : 1 628
    Points
    1 628
    Par défaut
    Si tu modifie le terme réécriture par refactoring (refactorisation, remaniement ...) alors je serais encore plus d'accord
    Échouer, c'est avoir la possibilité de recommencer de manière plus intelligente.

    Twitter Blog Mon site

    Mon article sur l'agilité

  6. #466
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par rad_hass Voir le message
    Si tu modifie le terme réécriture par refactoring (refactorisation, remaniement ...) alors je serais encore plus d'accord
    eh bien moi non

    refactoring peut apparaître avec des changements de paradigmes...

    réécriture est plus restreint, à mon sens, et ne comporte pas en tant que tel un changement de paradigme (mais sans doute des posibilités de changement de langage)..


    M'enfin..

    Où l'on voit bien que les termes étant flous, leur usage l'est tout autant..
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  7. #467
    Inactif  
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    357
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 357
    Points : 637
    Points
    637
    Par défaut
    Citation Envoyé par souviron34 Voir le message
    eh bien moi non

    refactoring peut apparaître avec des changements de paradigmes...

    réécriture est plus restreint, à mon sens, et ne comporte pas en tant que tel un changement de paradigme (mais sans doute des posibilités de changement de langage)..


    M'enfin..

    Où l'on voit bien que les termes étant flous, leur usage l'est tout autant..
    Refactoring n'est pas un terme flou (bien au contraire), et en général il ne s'accompagne pas de changement de paradigme (je dis en général car dans le cas de legacy code ça pourrait se discuter).

  8. #468
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par Furikawari Voir le message
    Refactoring n'est pas un terme flou (bien au contraire), et en général il ne s'accompagne pas de changement de paradigme (je dis en général car dans le cas de legacy code ça pourrait se discuter).
    Il y a là comme une contradiction, non ??

    • Ou bien c'est précis, et il n'y a pas d'exception
    • Ou bien c'est flou, et dans certains cas le sens n'est pas le même...


    De même, dans combien de cas "refactoring" n'est pas utilisé pour du "legacy code" ??

    Et quelle est ta définition d'un "legacy code" ??
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  9. #469
    Inactif  
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    357
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 357
    Points : 637
    Points
    637
    Par défaut
    Citation Envoyé par souviron34 Voir le message
    Il y a là comme une contradiction, non ??

    • Ou bien c'est précis, et il n'y a pas d'exception
    • Ou bien c'est flou, et dans certains cas le sens n'est pas le même...


    De même, dans combien de cas "refactoring" n'est pas utilisé pour du "legacy code" ??

    Et quelle est ta définition d'un "legacy code" ??
    Tu devrais lire 2-3 articles sur le refactoring avant de le critiquer, visiblement tu n'y connais rien. Tu peux commencer par par exemple.

  10. #470
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par Furikawari Voir le message
    Tu devrais lire 2-3 articles sur le refactoring avant de le critiquer, visiblement tu n'y connais rien. Tu peux commencer par par exemple.


    je ne connais peut-être (certainement) pas la théorie, mais j'ai déjà été sur 3 projets dans les dernières années où on m'a dit que l'on faisait du "refactoring"..

    Alors je ne sais pas si tout le monde (probablement) utilise mal le mot, mais l'industrie et les Chefs de Projets et Directeurs Techniques que j'ai rencontré n'y connaissent rien alors...

    Ce qui est vraisemblable, mais donc par conséquent n'enlève strictement rien au flou artistique...


    Et tu n'as pas répondu à ma question par rapport à la définition de "legacy code" par rapport au reste...
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  11. #471
    Inactif  
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    357
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 357
    Points : 637
    Points
    637
    Par défaut
    Citation Envoyé par souviron34 Voir le message


    je ne connais peut-être (certainement) pas la théorie, mais j'ai déjà été sur 3 projets dans les dernières années où on m'a dit que l'on faisait du "refactoring"..

    Alors je ne sais pas si tout le monde (probablement) utilise mal le mot, mais l'industrie et les Chefs de Projets et Directeurs Techniques que j'ai rencontré n'y connaissent rien alors...

    Ce qui est vraisemblable, mais donc par conséquent n'enlève strictement rien au flou artistique...


    Et tu n'as pas répondu à ma question par rapport à la définition de "legacy code" par rapport au reste...
    C'est vrais que les chefs de projets détiennent la vérité absolue et sont représentatifs du travail des développeurs...

    S'il te manque des définitions => google est ton ami.

  12. #472
    Membre éprouvé Avatar de I_believe_in_code
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    219
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 219
    Points : 1 043
    Points
    1 043
    Par défaut
    Citation Envoyé par koala01 Voir le message
    Idéalement un code propre serait exempt de bug

    Si tu remplace le terme "modifier" par "réécrire", je suis d'accord...
    Je maintiens le terme "modifier". Il semble utopique qu'un bout de code puisse paraître propre aux yeux de toutes les personnes qui auront à le lire, étant donné que la propreté du code est une notion subjective. Une application est bien plus facile à maintenir si on a jamais besoin de modifier le code qui existe déjà, mais seulement d'en ajouter.

    Citation Envoyé par koala01 Voir le message
    Je pinaille sur le terme, mais une modification du code peut très bien survenir simplement parce que, le temps aidant, tu as eu l'occasion de te rendre compte de certaines faiblesses de conception et que tu as décidé (ou du) revoir une partie de celle-ci,
    A mon sens une bonne conception est avant tout une conception qui permet d'écrire une application où on aura uniquement besoin d'ajouter du code, et non d'en modifier.

    Citation Envoyé par koala01 Voir le message
    alors qu'une réécriture sera plutôt due à l'impossibilité du lecteur de comprendre le raisonnement que l'auteur a pu suivre
    Comment peut-on réécrire un code qu'on ne comprend pas ? Cette notion de réécriture ne me plaît guère. Elle suppose que la personne qui réécrit fera forcément plus propre que les auteurs précédents. Mais ce n'est pas le cas : elle fera plus propre à ses yeux. Peut-être que le prochain lecteur du code trouvera à son tour que le code est illisible et réécrira à son tour. On n'en finit plus. Chacun pense qu'il écrit du code plus propre que les autres.

    La maintenabilité d'un code ne réside pas dans la façon dont il est écrit mais bien dans sa conception : une bonne conception et il n'y a pas besoin de modifier, juste d'ajouter.

  13. #473
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 69
    Points : 89
    Points
    89
    Par défaut
    Citation Envoyé par andr386 Voir le message
    Un code propre pour moi c'est aussi un code 'stupide'.
    En tout cas très simple, facilement lisible, facilement compréhensible
    et facilement deboguable par quelqu'un d'autre.
    Donc éviter MVC...

  14. #474
    Membre actif Avatar de el_pedro
    Homme Profil pro
    Inscrit en
    Août 2008
    Messages
    200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 200
    Points : 236
    Points
    236
    Par défaut
    Pour moi un code propre n'est pas forcement commenté. C'est un code qui suit un découpage logique et intelligent et qui s'y tiens.

  15. #475
    Expert confirmé

    Profil pro
    Leader Technique
    Inscrit en
    Juin 2005
    Messages
    1 756
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 756
    Points : 4 170
    Points
    4 170
    Par défaut
    Citation Envoyé par rad_hass Voir le message
    Si tu modifie le terme réécriture par refactoring (refactorisation, remaniement ...) alors je serais encore plus d'accord
    Ben je ne suis pas d'accord non plus. Peut-être que je ne connais pas le terme "refactoring" moi non plus, mais pour moi, du refactoring c'est prendre un code et le transformer pour qu'il fasse exactement la même chose tout en l'écrivant différemment : Renommer une méthode (ou une variable), changer l'ordre de ses paramètres d'appels, factoriser du code qui se répète en le remplaçant par un appel à une seul et même méthode...
    Bref, qu'en j'entends refactoring, il s'agit ni plus ni moins que de cosmétique. Tu ne remets jamais en cause l'algorithme ni la conception elle même.
    Si ça va plus loin, je ne parles plus de "refactoring" mais de "rework". Ce qui n'est rien d'autre qu'un terme anglais pour dire "réécrire".

    Or un code sale deviendra rarement propre en ne faisant qu'une succession de transformations équivalentes entre elles.

    Le terme "réécrire" est très clair : Tu prends l'existant, tu le jettes à la poubelle et tu recommences comme s'il n'avait jamais existé. (celà dit, c'est vrai qu'un code peut être sale sans nécessité pour autant une réécriture complète)...

    Citation Envoyé par I_believe_in_code
    Une application est bien plus facile à maintenir si on a jamais besoin de modifier le code qui existe déjà
    Malheureusement, la maintenance ne se résume pas à de la maintenance évolutive.
    Il y a énormément de cas dans l'informatique ou tu dois modifier un code qui était parfaitement propre :
    - Déjà un code peut être propre tout en étant bogué. Difficile de corriger le bogue sans le modifier...
    - Ensuite, même si le code est parfait rien ne te dit que lorsque le client aura l'appli entre les mains, il ne te dira pas : "a mais non, ce n'est pas ce que je veux", ou encore "ben oui, c'est bien ce que j'ai demandé, mais en fait non, maintenant je me rends compte que j'avais besoin que ça fonctionne différemment", ou encore : "ben en fait, j'avais rien compris moi même avant de le demander, et maintenant que j'ai compris, ben va falloir modifier deux ou trois choses".

    Comment peut-on réécrire un code qu'on ne comprend pas ?
    C'est très simple : Tu connais le projet, tu connais les spécifications. Tu sais que lorsque tu appelles cette méthode, elle doit réaliser ce calcul. Les tests te montre qu'elle calcule faux. Tu rentres dans le code pour la déboguer et lorsque tu vois l'usine à gaz totalement incompréhensible qui se trouve derrière alors que le problème était tout simple, tu te dit : J'aurais plus vite fait de tout réécrire plutôt que d'essayer de comprendre ce que le mec avant moi a voulu faire...

  16. #476
    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
    Citation Envoyé par Franck SORIANO Voir le message
    Or un code sale deviendra rarement propre en ne faisant qu'une succession de transformations équivalentes entre elles.
    Tu as raison de dire rarement car si tout code sale ne peut pas être lavé en machine, euh ... refactorer, parfois, un bon renommage des paramètres, des méthodes peut le rendre plus propre

    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.

  17. #477
    Expert éminent sénior

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 603
    Détails du profil
    Informations personnelles :
    Âge : 66
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 603
    Points : 17 913
    Points
    17 913
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par Franck SORIANO Voir le message
    Peut-être que je ne connais pas le terme "refactoring" moi non plus
    Merci je me sens moins seul
    "Un homme sage ne croit que la moitié de ce qu’il lit. Plus sage encore, il sait laquelle".

    Consultant indépendant.
    Architecture systèmes complexes. Programmation grosses applications critiques. Ergonomie.
    C, Fortran, XWindow/Motif, Java

    Je ne réponds pas aux MP techniques

  18. #478
    Membre expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    Par défaut
    C'est très simple : Tu connais le projet, tu connais les spécifications. Tu sais que lorsque tu appelles cette méthode, elle doit réaliser ce calcul. Les tests te montre qu'elle calcule faux. Tu rentres dans le code pour la déboguer et lorsque tu vois l'usine à gaz totalement incompréhensible qui se trouve derrière alors que le problème était tout simple, tu te dit : J'aurais plus vite fait de tout réécrire plutôt que d'essayer de comprendre ce que le mec avant moi a voulu faire...
    Là tu parle de correction de bug, qui implique parfois de refaire une portion non négligeable du code.

    dans le cadre du refactoring, si je ne me trompe pas, on parle de refaire un code qui marche afin de le rendre plus facilement maintenable et/ou plus efficace et/ou plus logique?
    bazar: http://www.improetcompagnie.com/publ...ctacles-6.html

    BÉPO la disposition de clavier francophone, ergonomique et libre: http://bepo.fr/wiki/Accueil

    Emacs Wiki: http://www.emacswiki.org/

    En attente de ce que produira: http://www.pushmid.com

  19. #479
    Inactif  
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    357
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 357
    Points : 637
    Points
    637
    Par défaut
    Citation Envoyé par souviron34 Voir le message
    Merci je me sens moins seul
    C'était ironique étant donné que sa vision est exacte...

    Edit "presque exacte" puisque justement l'objectif est que la succession de transformation équivalente aboutisse à un code propre. Cela dit ça demande du temps, mais comme le dit Benwit, bien souvent le fait de renommer et de faire de l'extraction de méthode suffit déjà à y voir beaucoup plus clair.

  20. #480
    Membre expérimenté
    Profil pro
    chercheur
    Inscrit en
    Avril 2004
    Messages
    830
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : chercheur

    Informations forums :
    Inscription : Avril 2004
    Messages : 830
    Points : 1 453
    Points
    1 453
    Par défaut Voilà une bonne définition
    Franck SORIANO : Tu sais que lorsque tu appelles cette méthode, elle doit réaliser ce calcul.
    Voilà une bonne définition d'un code déjà bien propre
    Ce qui s'énonce clairement se conçoit bien ( Le hautbois)

Discussions similaires

  1. Qu'est ce que cela veux dire un "code propre" selon-vous ?
    Par kagura dans le forum Général Conception Web
    Réponses: 45
    Dernier message: 09/02/2016, 14h22
  2. [Tableaux] Retour chariot pour un code HTML propre
    Par beastman007 dans le forum Langage
    Réponses: 10
    Dernier message: 09/03/2006, 17h43
  3. Code CSS propre
    Par keawee dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 21/10/2005, 21h59

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