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

Langage Perl Discussion :

optimisation code condition


Sujet :

Langage Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Mars 2006
    Messages
    624
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 624
    Par défaut optimisation code condition
    Bonjour;

    Comment puis je faire pour optimiser mon code, afin que ma condition soit plus lisible.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    my $InitEnv=$InitTableau[$#InitTableau];
    if ( $InitEnv ne "EXP" &&   $InitEnv ne "ENV1" &&  $InitEnv ne "ENV2" &&  $InitEnv ne "ENV_REC2" &&  $InitEnv ne "ENV_REC3" &&  $InitEnv ne "ENV_4" &&  $InitEnv ne "ENV8" &&  $InitEnv ne "ENV04" &&  $InitEnv ne "PROD") 
    	{
    	print "Erreur repertoire de lancement: $InitBaseRep \n" ;
    	print "Il faut se placer dans un repertoire correspondant a l'environnement \n";
    	exit ;
    	}
    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Billets dans le blog
    1
    Par défaut
    Bonsoir,

    Peut-être une expression régulière:

    if ( $InitEnv ne "EXP" && $InitEnv ne "ENV1" && $InitEnv ne "ENV2" && $InitEnv ne "ENV_REC2" && $InitEnv ne "ENV_REC3" && $InitEnv ne "ENV_4" && $InitEnv ne "ENV8" && $InitEnv ne "ENV04" && $InitEnv ne "PROD")

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if ( $InitEnv !~ /EXP|ENV[128]|ENV_REC[23]|ENV[_0]4|PROD/) {
        # ...
    }
    C'est beaucoup plus concis, mais certainement pas plus lisible. Avec le modificateur x, on peut l'améliorer en:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    if ( $InitEnv !~ /   EXP
                       | ENV     [128]
                       | ENV_REC [23]
                       | ENV     [_0]4
                       | PROD
                        /x
       ) {
        # ...
    }
    }
    Ce qui est déjà un peu mieux.

    Mais je recommanderais plutôt de stocker tes environnements dans un hash:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    my %env = map { $_ => 1 } qw /  EXP  ENV1  ENV2  ENV_REC2  ENV_REC3  ENV_4  ENV8  ENV04  PROD /;
    unless (exists $env{$InitEnv}) {
        # ...
    }

    C'est beaucoup plus maintenable si tu dois ajouter ou supprimer un environnement permis.

Discussions similaires

  1. Optimisation code pour gagner en rapidité
    Par polodu84 dans le forum MATLAB
    Réponses: 2
    Dernier message: 05/03/2008, 15h32
  2. Réponses: 13
    Dernier message: 22/02/2008, 18h55
  3. Optimiser code VBA
    Par willytito dans le forum VBA Access
    Réponses: 5
    Dernier message: 19/11/2007, 09h49
  4. Réponses: 1
    Dernier message: 04/12/2006, 07h55
  5. [Compilateur] Optimisation des conditions
    Par Pedro dans le forum Langage
    Réponses: 2
    Dernier message: 16/06/2004, 13h49

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