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

Actualités Discussion :

Le pire bout de code que vous ayez vu

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 23
    Par défaut
    Citation Envoyé par Gordon Fowler Voir le message
    les variables sont passées par copie de la valeur
    Est ce une généralité à propos de Java ou spécifique à l'exmple ?
    Car si c'est le cas un, je suis en désaccord.

    Cela impliquerait qu'un objet uniquement passé en paramètre n'est jamais modifiable dans la méthode comme cela est possible en C avec la notion de pointeur.


    Donc ce qui s'amuse à faire des codes du genre car l'objet à subit un traitement le modifiant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
       public Object   doSiomething(Object  object ){
    
          //code
            return object;
    
        }
    n'ont pas compris comment sont traités les paramètres en Java.

    Le return est inutile sauf quelques cas (objets immuables comme l'objet LocalDate de l'api JodaTime que je recommande vivement par ailleurs...)

  2. #2
    Membre extrêmement actif
    Profil pro
    Développeur Java Indépendant
    Inscrit en
    Mai 2007
    Messages
    1 333
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Java Indépendant

    Informations forums :
    Inscription : Mai 2007
    Messages : 1 333
    Par défaut
    Citation Envoyé par fredop Voir le message
    Est ce une généralité à propos de Java ou spécifique à l'exmple ?
    Car si c'est le cas un, je suis en désaccord.
    En java c'est une généralité, toutes les variables sont passées par copie de leur valeur.

    Citation Envoyé par fredop Voir le message
    Cela impliquerait qu'un objet uniquement passé en paramètre n'est jamais modifiable dans la méthode comme cela est possible en C avec la notion de pointeur.
    On ne peut donc pas passer un objet en paramètre.
    On passe une copie de la référence à cette objet, donc on peut ensuite faire des modifications sur cette objet, mais toute réasignation de la copie de la référence à l'objet est sans effet sur la référence initiale.


    Donc ce qui s'amuse à faire des codes du genre car l'objet à subit un traitement le modifiant:

    Citation Envoyé par fredop Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
       public Object   doSiomething(Object  object ){
    
          //code
            return object;
    
        }
    n'ont pas compris comment sont traités les paramètres en Java.
    Le return est inutile sauf quelques cas (objets immuables comme l'objet LocalDate de l'api JodaTime que je recommande vivement par ailleurs...)
    C'est en effet inutile si ta variable "object" ne pointe pas vers un nouvel object.
    Après je sais pas quel est la meilleur solution en terme de visibilité.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Cette technique permet de faire des choses du style

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FaireEncoreAutreChose(FareAutreChose(mafonction(monObjet)))
    Plutot que

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    mafonction(monObjet)
    FareAutreChose(monObjet)
    FaireEncoreAutreChose(monObjet)
    Ce pattern à un nom et est vachement utilisé pour les requète NHibernate par exemple ou la majorité des fonction retourne this

  4. #4
    Membre extrêmement actif
    Profil pro
    Développeur Java Indépendant
    Inscrit en
    Mai 2007
    Messages
    1 333
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Java Indépendant

    Informations forums :
    Inscription : Mai 2007
    Messages : 1 333
    Par défaut
    Citation Envoyé par Bourgui Voir le message
    ...
    Oh j'y avait pas pensé merci de l'info !

  5. #5
    Invité
    Invité(e)
    Par défaut
    j'ai trouvé comment ça s'appelle : "Fluent interface"

    http://en.wikipedia.org/wiki/Fluent_interface#C.23

  6. #6
    Membre extrêmement actif

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Par défaut
    Citation Envoyé par Bourgui Voir le message
    Cette technique permet de faire des choses du style

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FaireEncoreAutreChose(FareAutreChose(mafonction(monObjet)))
    Plutot que

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    mafonction(monObjet)
    FareAutreChose(monObjet)
    FaireEncoreAutreChose(monObjet)
    Ce pattern à un nom et est vachement utilisé pour les requète NHibernate par exemple ou la majorité des fonction retourne this
    C'est justement ce genre de code qu'il ne faut pas faire.

    D'ailleurs puisque tu parles de pattern, c'est le pattern de responsabilité 'Protection des variations' ou plus connu peut-être sous le nom 'Ne parlez pas aux inconnus' qui me fait penser à cela.

    le code me fait aussi penser au pattern décorateur mais poussé à l'extrême et mal utilisé


    Bref, ton premier bout de code (pattern hibernate lol) est sale, je préfére de loin retrouver le second code

  7. #7
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 396
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 396
    Par défaut
    Pourtant, en C++ c'est courant (sauf qu'il y a des points ou des chevrons à la place des appels imbriqués).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  8. #8
    Membre extrêmement actif
    Profil pro
    Développeur Java Indépendant
    Inscrit en
    Mai 2007
    Messages
    1 333
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Java Indépendant

    Informations forums :
    Inscription : Mai 2007
    Messages : 1 333
    Par défaut
    Citation Envoyé par hegros Voir le message
    C'est justement ce genre de code qu'il ne faut pas faire.

    D'ailleurs puisque tu parles de pattern, c'est le pattern de responsabilité 'Protection des variations' ou plus connu peut-être sous le nom 'Ne parlez pas aux inconnus' qui me fait penser à cela.

    le code me fait aussi penser au pattern décorateur mais poussé à l'extrême et mal utilisé


    Bref, ton premier bout de code (pattern hibernate lol) est sale, je préfére de loin retrouver le second code
    Je vois pas en quoi le premier code parle plus aux inconnus que le second, c'est juste appeler plusieurs méthode sur un seul et même objet, quel est le problème ?

  9. #9
    Candidat au Club
    Inscrit en
    Mai 2010
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 3
    Par défaut
    Un magnifique code pour séparer la partie entière et la partie décimale en c# afin d'afficher un temps avec 3 chiffres pour les millisecondes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
                    double valeur;
                    [...]
                    // Update the time label
                    minute = (int)valeur / 60;
                    seconde = (int)valeur - minute * 60;
    
                    if (valeur.ToString().Split(',').Length >= 2)
                    {
                        miniseconde = valeur.ToString().Split(',')[1];
                        if (miniseconde.Length > 3)
                            miniseconde = miniseconde.Substring(0, 3);
                        else if (miniseconde.Length > 2)
                            miniseconde = miniseconde.Substring(0, 2) + "0";
                        else
                            miniseconde = miniseconde.Substring(0, 1) + "00";
                    }
                    else
                    {
                        miniseconde = "000";
                    }
    C'est pas beau ça ? Une convertion en string puis un split sur la virgule !
    Je travaille sur un xp français et ça m'a pris un bon moment pour comprendre pourquoi l'appli ne fonctionnait pas correctement sur windaube embedded en anglais. Hé oui sur un os en angliche quand on convertit un double en string ça met un . pas une virgule...
    remplacé en une ligne par miniseconde=String.Format("{0:000}", (valeur - minute * 60 - seconde) * 1000);

  10. #10
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par tomtom83 Voir le message
    remplacé en une ligne par miniseconde=String.Format("{0:000}", (valeur - minute * 60 - seconde) * 1000);
    La correction ne valant pas beaucoup plus cher que le code critiqué, puisqu'elle démontre l'égal ignorance du TimeSpan.

  11. #11
    Invité de passage
    Inscrit en
    Novembre 2010
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 1
    Par défaut
    Obligé de citer l'IOCCC...
    http://www.de.ioccc.org/years.html

    ex:
    #include <stdio.h>
    #include <stdlib.h>
    #include <math.h>

    #define _ ;double
    #define void x,x
    #define case(break,default) break[O]:default[O]:
    #define switch(bool) ;for(;x<bool;
    #define do(if,else) inIine(else)>int##if?
    #define true (--void++)
    #define false (++void--)

    char*O=" <60>!?\\\n"_ doubIe[010]_ int0,int1 _ Iong=0 _ inIine(int eIse){int
    O1O=!O _ l=!O;for(;O1O<010;++O1O)l+=(O1O[doubIe]*pow(eIse,O1O));return l;}int
    main(int booI,char*eIse[]){int I=1,x=-*O;if(eIse){for(;I<010+1;I++)I[doubIe-1]
    =booI>I?atof(I[eIse]):!O switch(*O)x++)abs(inIine(x))>Iong&&(Iong=abs(inIine(x
    )));int1=Iong;main(-*O>>1,0);}else{if(booI<*O>>1){int0=int1;int1=int0-2*Iong/0
    [O]switch(5[O]))putchar(x-*O?(int0>=inIine(x)&&do(1,x)do(0,true)do(0,false)
    case(2,1)do(1,true)do(0,false)6[O]case(-3,6)do(0,false)6[O]-3[O]:do(1,false)
    case(5,4)x?booI?0:6[O]:7[O])+*O:8[O]),x++;main(++booI,0);}}}

  12. #12
    Membre Expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Par défaut
    Citation Envoyé par Khoyo Voir le message
    Obligé de citer l'IOCCC...
    http://www.de.ioccc.org/years.html

    ex:
    Haha, excelent, c'est des artistes : http://www.de.ioccc.org/2004/newbern.c

  13. #13
    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 : 49

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Par défaut
    Citation Envoyé par Khoyo Voir le message
    Obligé de citer l'IOCCC...
    http://www.de.ioccc.org/years.html

    ex:
    ça existe encore ce concours?
    Mais bon c'est peu être limite hors sujet je pense que l'on parle de code utilisé dans le cadre du boulot.

    je me souviens d'un sapin de noel, contenant du code c....

  14. #14
    Membre très actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2010
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2010
    Messages : 254
    Par défaut
    J'ai trouvé ce code dans un dans un de mes projets fait par un de mes binômes en C
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (write(1, buffer, buff_size) < 0)
    {
       write(1, "write failed\n", 30);
       exit(0);
    }

  15. #15
    Membre Expert Avatar de Barsy
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    1 484
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Loire Atlantique (Pays de la Loire)

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

    Informations forums :
    Inscription : Octobre 2007
    Messages : 1 484
    Par défaut
    Ce matin, dans le projet que je suis en train de reprendre, je suis tombé sur ce code :

    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    int Id;
    if (int.TryParse(maValeur.ToString(), out Id))
    {
    	if (Id.ToString().Contains("-"))
    		Id = Convert.ToInt32(Id.ToString().Replace("-", String.Empty));
    }

    Le code ci-dessus permet de retourner la valeur absolue d'un entier, efficace non ?

  16. #16
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par Barsy Voir le message
    Le code ci-dessus permet de retourner la valeur absolue d'un entier, efficace non ?
    Ouch c'est du lourd.

    Ou alors, le gars est payé à la ligne de code ? (mal, j'espère ).

Discussions similaires

  1. Quel est le pire bout de code que vous ayez jamais écrit ?
    Par Gordon Fowler dans le forum Débats sur le développement - Le Best Of
    Réponses: 61
    Dernier message: 31/10/2011, 12h18
  2. Quelle est la plus grosse erreur de programmation que vous ayez jamais commise ?
    Par Katleen Erna dans le forum Débats sur le développement - Le Best Of
    Réponses: 138
    Dernier message: 03/08/2011, 23h38
  3. Petit bout de code que je ne saisis pas trop
    Par MeTaLCaM dans le forum C#
    Réponses: 5
    Dernier message: 03/12/2009, 00h07
  4. [Vos débuts] Quel est le premier langage que vous ayez appris ?
    Par Commodore dans le forum La taverne du Club : Humour et divers
    Réponses: 171
    Dernier message: 02/02/2007, 14h43

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