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

avec Java Discussion :

Code spaghetti, visibilité du code


Sujet :

avec Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2013
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 11
    Points : 17
    Points
    17
    Par défaut Code spaghetti, visibilité du code
    Bonjour, je dois faire du code vraiment de base, que je vais devoir traduire en assembleur et en plein de language. Pricipalement je veux faire des pluriels sur des quantités. Voici mon code :

    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
    22
    23
        if (Total_Pieds == 1 && Total_Pouces > 0) {
            System.out.print(Total_Pieds + " pied ");
        }
     
        if (Total_Pieds == 1 && Total_Pouces == 0) {
            System.out.println(Total_Pieds + " pied");
        }
     
        if (Total_Pieds > 1 && Total_Pouces > 0) {
            System.out.print(Total_Pieds + " pieds ");
        }
     
        if (Total_Pieds > 1 && Total_Pouces == 0) {
            System.out.println(Total_Pieds + " pieds");
        }
     
        if (Total_Pieds == 0 && Total_Pouces == 0 || Total_Pouces == 1) {
            System.out.println(Total_Pouces + " pouce");
        }
     
        if (Total_Pouces > 1) {
            System.out.println(Total_Pouces + " pouces");
        }
    Tout fonctionne comme je le veux et comme cela doit fonctionner, comme certains cas ou 0 pouce, ou bien, 0 pied ne doit pas apparaitre.

    EX : 1 pied / 2 pieds / 2 pieds 1 pouce / 0 pouce / 11 pouces / ....

    Est-ce que il y a une facon plus esthétique et simple de vérifier ces conditions sans avoir a faire un spaghetti de code avec plein de IF. Je peux toujours transformer cela en fonction, mais bon, j'hésite et je ne peux pas utiliser des fonctions trop avancés de java sinon cela va foirer en assembleur.

    Pour ce qui est des println et print, c'est normal, car je dois absolument terminer l'affichage de la ligne avec aucun espace vide.

    Merci de votre aide !

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    281
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 281
    Points : 321
    Points
    321
    Par défaut
    Un moment donnée, même si tu dois faire une fonction, si tu dois différencier les cas, tu devras forcement passer par ce genre de truc. Sinon il y a le case of mais ça revient un peu au même.

    PS : J'ai mis case of au lieu de switch case. (habitude de premier language appris)

  3. #3
    Membre actif Avatar de Lician
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Mars 2011
    Messages
    93
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Services de proximité

    Informations forums :
    Inscription : Mars 2011
    Messages : 93
    Points : 230
    Points
    230
    Par défaut
    Hello!

    Tu peux effectivement passer par un switch case...
    Ça sera plus propre et ça t'évitera la succession des if ou if else.

    Surtout que dans ton cas les tests sont tous de même "types" donc oui... Switch case!

    Bon courage
    Keep enjoy'n the ride and let's rock...
    Pensez au bouton et à voter sur les messages utiles pour les autres!
    --------
    Lician - https://chat.developpez.com/ - http://87.98.168.209/

  4. #4
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 211
    Points : 8 316
    Points
    8 316
    Billets dans le blog
    52
    Par défaut
    La logique de construction de ton message n'est pas apparent dans ton code. Pourtant cela devrait être le cas !
    Je te propose une solution qui mes un peu plus en valeur la logique de construction :
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    package snippet;
     
    public class Snippet {
    	private static final String SPACE = " ";
     
    	public static void main(String[] args) {
    		print(0,0);
    		print(0,1);
    		print(0,2);
    		print(1,0);
    		print(2,0);
    		print(2,1);
    		print(2,2);
    	}
     
    	public static void print(int totalPied, int totalPouce) {
    		StringBuilder message = new StringBuilder();
    		if (totalPied >= 1) {
    			// Debut partie Pied
    			message.append(totalPied);
    			message.append(SPACE);
    			message.append("pied");
    			if (totalPied > 1) {
    				message.append("s");
    			}
    			// Fin partie Pied
    			if (totalPouce >= 0) {
    				message.append(SPACE);
    			}
    		}
    		if (totalPouce >= 1 || totalPied <= 0) {
    			// Debut partie Pouce
    			message.append(totalPouce);
    			message.append(SPACE);
    			message.append("pouce");
    			if (totalPouce > 1) {
    				message.append("s");
    			}
    			// Fin partie Pouce
    		}
    		System.out.println(message);
    	}
    }
    Les deux parties que j'ai mise en valeur avec des commentaire pourrait-être factoriser ou extraite. Pour voir seulement la logique de fusion d'affichage :

    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    public static void print(int totalPied, int totalPouce) {
    		StringBuilder message = new StringBuilder();
    		if (totalPied >= 1) {
    			printPied(totalPied, message);
    			if (totalPouce >= 0) {
    				message.append(SPACE);
    			}
    		}
    		if (totalPouce >= 1 || totalPied <= 0) {
    			printPouce(totalPouce, message);
    		}
    		System.out.println(message);
    	}
     
    	private static void printPouce(int totalPouce, StringBuilder message) {
    		message.append(totalPouce);
    		message.append(SPACE);
    		message.append("pouce");
    		if (totalPouce > 1) {
    			message.append("s");
    		}
    	}
     
    	private static void printPied(int totalPied, StringBuilder message) {
    		message.append(totalPied);
    		message.append(SPACE);
    		message.append("pied");
    		if (totalPied > 1) {
    			message.append("s");
    		}
    	}
    Cela me semble plus simple à prendre ou reprendre en main.

    Cordialement,
    Patrick Kolodziejczyk.
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

  5. #5
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Allez, amusons nous, mais c'est de la masturbation intellectuelle

    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
     
        if (Total_Pieds >0){
            System.out.print(Total_Pieds + " pied");
            if (Total_Pieds >1)
               System.out.print("s"); // pluriel
            if (Total_Pouces > 0)
               System.out.print(" "); // espace
     
        }
        if (Total_Pouces >0 || Total_Pieds == 0){
           System.out.print(Total_Pouces + " pouce");
           if (Total_Pouces > 1) 
               System.out.print("s");
        }
        System.out.println();

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2013
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 11
    Points : 17
    Points
    17
    Par défaut
    Merci à tous ! Je vais regarder cela et changer mon code même ci cela ne concerne que l'affichage, je préfère que mon code soit élégant et visible ! Je saute dans la documentation et la traduction maintenant

    Merci encore !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Razor et WebMatrix = le retour du code spaghetti ?
    Par camus3 dans le forum WebMatrix
    Réponses: 2
    Dernier message: 06/11/2010, 17h12
  2. Non visibilité du code
    Par new_wave dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 08/06/2010, 08h48
  3. visibilité du code de connection à la database
    Par bris dans le forum Débuter
    Réponses: 4
    Dernier message: 27/02/2006, 16h10
  4. [code::blocks] Completion de code
    Par anykeyh dans le forum Code::Blocks
    Réponses: 1
    Dernier message: 20/12/2005, 16h53
  5. [JS] Appeler du code C# depuis du code JS
    Par DontNet dans le forum ASP.NET
    Réponses: 3
    Dernier message: 05/05/2005, 19h00

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