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

C Discussion :

propreté de code


Sujet :

C

  1. #1
    Provisoirement toléré
    Inscrit en
    Octobre 2002
    Messages
    214
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 214
    Points : 33
    Points
    33
    Par défaut propreté de code
    Bonsoir , j'ai écrit un programme composé de 2 fichiers qui affiche une table de conversion des euros en francs , j'aimerais juste que quelqu'un de super maniaque et bon en C me dise si il y a de petites choses à régler pour que le code soit plus propre , merci :

    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
     
     
    #include <stdio.h>
     
    int my_euros(void);
     
    int main(void)
     
    {
     
    my_euros(void);
     
    return 0;
     
    }
    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
     
     
    #include <stdio.h>
     
    int my_euros(void)
     
    {
     
    float euro = 1;
     
    for ( euro = 0; euro <500; euro = euro + 20 )
    {
    printf("%6.2f %6.2f", euro, euro * 6.5);
    }
    return 0;
    }
    PS : j'ai juste le droit aux boucles et à printf , j'ai pas fait d'erreur çà va ?

  2. #2
    jmv
    jmv est déconnecté
    Membre confirmé Avatar de jmv
    Profil pro
    Enseignant
    Inscrit en
    Mai 2004
    Messages
    395
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Mai 2004
    Messages : 395
    Points : 603
    Points
    603
    Par défaut
    je ne suis ni maniaque ni bon en C mais il me semble qu'1 euro = 6.55957F (et ça serait bien de mettre ça dans une constante).

  3. #3
    Provisoirement toléré
    Inscrit en
    Octobre 2002
    Messages
    214
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 214
    Points : 33
    Points
    33
    Par défaut
    oui bon ce genre d'erreur n'a pas d'importance lol , ce qui m'intéresse surtout c'est voir si j'ai pas fait de minuscules erreur au niveau du code en C...,,au passage , si j'ai :

    float euro = 1;

    for ( euro = 0; euro < 500....


    est ce que je peux l'écrire comme ceci :


    for ( float euro = 1; euro < 500...

    je veux dire que je peux pas déclarer une variable au début de la boucle for , si ?

  4. #4
    jmv
    jmv est déconnecté
    Membre confirmé Avatar de jmv
    Profil pro
    Enseignant
    Inscrit en
    Mai 2004
    Messages
    395
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Mai 2004
    Messages : 395
    Points : 603
    Points
    603
    Par défaut
    je ne programme plus qu'en C++ où on peut faire ce genre de chose. Il me semble que ça passe en C maintenant.

    sinon si tu veux des critiques :
    - l'indentation de ton prog est à revoir
    - met le rapport EURO/FRANC dans une constante.
    - pourquoi 2 fonctions ?
    - il n'y a jamais de retour à la ligne dans tes affichages ?
    - pourquoi euro est un float ? il est toujours entier
    - utilise l'opérateur +=
    [ajout] quand tu appeles ta fonction my_euros(), void est inutile - d'ailleurs je suis étonné que ça compile.

  5. #5
    Provisoirement toléré
    Inscrit en
    Octobre 2002
    Messages
    214
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 214
    Points : 33
    Points
    33
    Par défaut
    ok peux tu corriger çà s'il te plait ?

    j'ai fait 2 fichiers juste pour m'entrainer à compiler avec un makefile .

  6. #6
    Provisoirement toléré
    Inscrit en
    Octobre 2002
    Messages
    214
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 214
    Points : 33
    Points
    33
    Par défaut
    et 6.5 c'est un flottant pas un entier il me semble , les nombres à virgules sont des flottants .

  7. #7
    Membre Expert

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

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

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Points : 5 724
    Points
    5 724
    Par défaut
    en plus.

    -<stdio.h> n'est pas utile dans le fichier où se trouve le main.
    -inutile d'initialiser euroà 1 pour le remettre de suite à 0 aprés.
    -Pourquoi ne pas utiliser un fichier d'entete pour les prototypes de fonction et ainsi l'inclure dans les parties de programme qui les utilisent ?
    " Dis ce que tu veux qui insulte mon honneur car mon silence sera la réponse au mesquin.
    Je ne manque pas de réponse mais : il ne convient pas aux lions de répondre aux chiens ! " [Ash-Shafi'i ]

  8. #8
    Provisoirement toléré
    Inscrit en
    Octobre 2002
    Messages
    214
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 214
    Points : 33
    Points
    33
    Par défaut
    "-Pourquoi ne pas utiliser un fichier d'entete pour les prototypes de fonction et ainsi l'inclure dans les parties de programme qui les utilisent ?"

    peux tu préciser ce point et me donner l'exemple avec mon fichier , çà m'intéresse , merci .

  9. #9
    Membre expérimenté
    Inscrit en
    Décembre 2004
    Messages
    1 478
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 478
    Points : 1 664
    Points
    1 664
    Par défaut
    Citation Envoyé par jmv
    je ne programme plus qu'en C++ où on peut faire ce genre de chose. Il me semble que ça passe en C maintenant.
    Définir une variable dans un for(), non. C'est du C++. A ma connaissance, même C99 ne le permet pas.

    Pour répondre à Bidouba, c'est difficile de juger sur un exemple aussi trivial, qui ne nécessite pas de fonction en premier lieu. De plus, la valeur retournée par my_euros (drole de nom, aucun rapport avec ce qu'elle fait) est inutile. Comme il n'y pas d'erreur prévue dans la fonction, autant qu'elle ne retourne rien (void). Mais comme je l'écris plus haut, la fonction est inutile (j'imagine que c'est encore un test pour la compilation séparée).
    Sinon, ton code est propre mais mal indenté, et tu abuses des retours à la ligne.

    Citation Envoyé par Bibouda
    peux tu préciser ce point et me donner l'exemple avec mon fichier , çà m'intéresse , merci .
    Ouvre un livre de C ou un tutoriel sur l'Internet (liens sur ce site), par pitié! Tu ne vas pas apprendre en posant des questions ici.

  10. #10
    Rédacteur

    Avatar de gege2061
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2004
    Messages
    5 840
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Juin 2004
    Messages : 5 840
    Points : 11 625
    Points
    11 625
    Par défaut
    Citation Envoyé par DaZumba
    Définir une variable dans un for(), non. C'est du C++. A ma connaissance, même C99 ne le permet pas.
    Bien au contraire :
    • C90 : impossible pas de mixe code/déclaration
    • C99 : Ok, la variable n'existe plus à la de la boucle
    • C++ : a éviter, la porté de la variable n'est pas définie par la norme (donc on ne sais pas si la variable existe toujours après la boucle, ça dépend des compilateurs)

  11. #11
    Membre à l'essai
    Inscrit en
    Octobre 2005
    Messages
    14
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 14
    Points : 10
    Points
    10
    Par défaut
    pour ta variable euro, puisque tu l'initialises dans ta boucle tu n'a pas besoin d'initialiser cette derniere au début. Par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    float euro;
     
    for( euro = 0; euro < 500; euro += 20 )
    {
         // ton code
    }

  12. #12
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par Bibouda
    est ce que je peux l'écrire comme ceci :

    for ( float euro = 1; euro < 500...

    je veux dire que je peux pas déclarer une variable au début de la boucle for , si ?
    En C99, c'est possible.
    Pas de Wi-Fi à la maison : CPL

  13. #13
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut Re: propreté de code
    Citation Envoyé par Bibouda
    Bonsoir , j'ai écrit un programme composé de 2 fichiers qui affiche une table de conversion des euros en francs , j'aimerais juste que quelqu'un de super maniaque et bon en C me dise si il y a de petites choses à régler pour que le code soit plus propre , merci :

    Je recommande ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    #ifndef H_X
    #define H_X
     
    /* x.h */
     
    int my_euros (void);
     
    #endif
    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
     
    /* x.c */
    #include "x.h"
     
    #include <stdio.h>
     
    #define F_PER_EURO 6.55957
     
    int my_euros (void)
    {
       double euro;
     
       for (euro = 0; euro < 500; euro += 20)
       {
          printf ("%6.2f %7.2f\n", euro, euro * F_PER_EURO);
       }
       return 0;
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    #include "x.h"
     
    #include <stdio.h>
     
    int main (void)
    {
       my_euros ();
     
       return 0;
    }
    Ce qui produit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
      0.00    0.00
     20.00  131.19
     40.00  262.38
     60.00  393.57
     80.00  524.77
    100.00  655.96
    120.00  787.15
    140.00  918.34
    160.00 1049.53
    <...>
    440.00 2886.21
    460.00 3017.40
    480.00 3148.59
    Pas de Wi-Fi à la maison : CPL

  14. #14
    Membre expérimenté
    Inscrit en
    Décembre 2004
    Messages
    1 478
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 478
    Points : 1 664
    Points
    1 664
    Par défaut
    Citation Envoyé par gege2061
    Bien au contraire :
    • C90 : impossible pas de mixe code/déclaration
    • C99 : Ok, la variable n'existe plus à la de la boucle
    Tu veux dire qu'en C99 on peut faire for(int i = 0; ...) ? Je ne trouve cela nul part dans le dernier draft de la norme...

  15. #15
    Rédacteur

    Avatar de gege2061
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2004
    Messages
    5 840
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Juin 2004
    Messages : 5 840
    Points : 11 625
    Points
    11 625
    Par défaut
    Citation Envoyé par DaZumba
    Citation Envoyé par gege2061
    Bien au contraire :
    • C90 : impossible pas de mixe code/déclaration
    • C99 : Ok, la variable n'existe plus à la de la boucle
    Tu veux dire qu'en C99 on peut faire for(int i = 0; ...) ? Je ne trouve cela nul part dans le dernier draft de la norme...
    What are for loop intializers?
    Il suffit d'essayer avec un compilateur bien réglé!

  16. #16
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par DaZumba
    Citation Envoyé par gege2061
    Bien au contraire :
    • C90 : impossible pas de mixe code/déclaration
    • C99 : Ok, la variable n'existe plus à la de la boucle
    Tu veux dire qu'en C99 on peut faire for(int i = 0; ...) ? Je ne trouve cela nul part dans le dernier draft de la norme...
    Citation Envoyé par n1124
    6.8.5 Iteration statements
    Syntax
    1 iteration-statement:
    while ( expression ) statement
    do statement while ( expression ) ;
    for ( expressionopt ; expressionopt ; expressionopt ) statement
    for ( declaration expressionopt ; expressionopt ) statement
    Constraints
    2 The controlling expression of an iteration statement shall have scalar type.
    3 The declaration part of a for statement shall only declare identifiers for objects having
    storage class auto or register.
    Semantics
    4 An iteration statement causes a statement called the loop body to be executed repeatedly
    until the controlling expression compares equal to 0.
    5 An iteration statement is a block whose scope is a strict subset of the scope of its
    enclosing block. The loop body is also a block whose scope is a strict subset of the scope
    of the iteration statement.
    Pas de Wi-Fi à la maison : CPL

  17. #17
    Membre expérimenté
    Inscrit en
    Décembre 2004
    Messages
    1 478
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 478
    Points : 1 664
    Points
    1 664
    Par défaut
    Merci pour le lien. Encore un ajout C99 que je n'utiliserai jamais...

    Citation Envoyé par gege2061
    Il suffit d'essayer avec un compilateur bien réglé!
    Certes. Mon reglage par defaut de gcc inclus -ansi -pedantic, donc je ne risque pas d'utiliser ce genre de choses.

    Edit: Merci Emmanuel, en survolant cette section, je n'avais pas observe le "declaration".

  18. #18
    Rédacteur

    Avatar de gege2061
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2004
    Messages
    5 840
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Juin 2004
    Messages : 5 840
    Points : 11 625
    Points
    11 625
    Par défaut
    Citation Envoyé par DaZumba
    Certes. Mon reglage par defaut de gcc inclus -ansi -pedantic, donc je ne risque pas d'utiliser ce genre de choses.
    Suffit de remplacer le -ansi par -std=c99

    Par contre pour ce qui ai du c++, mes vagues souvenirs sont inexactes puisque la norme a était revu et indique le même comportement qu'en C99 mais son utilisation fait couler le l'encre : Portee des variables pour boucle for

Discussions similaires

  1. proprete du code avec define
    Par lilington dans le forum Débuter
    Réponses: 6
    Dernier message: 24/02/2012, 11h41
  2. Votre avis sur la "propreté" de ce code ?
    Par Christophe Charron dans le forum Android
    Réponses: 12
    Dernier message: 20/08/2011, 15h12
  3. Propreté d'un petit bout de code
    Par grafik.muzik dans le forum Débuter
    Réponses: 5
    Dernier message: 30/12/2008, 21h46
  4. [MFC/Outlook] Propreté de code
    Par SmOkEiSBaD dans le forum MFC
    Réponses: 2
    Dernier message: 02/05/2008, 10h10
  5. propreté d'écriture d'un code
    Par Ganondorf dans le forum Langage
    Réponses: 0
    Dernier message: 18/10/2007, 23h52

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