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 Java Discussion :

Problème expression ternaire


Sujet :

Langage Java

  1. #1
    Membre expérimenté
    Avatar de l4r3nZu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Janvier 2010
    Messages : 154
    Par défaut Problème expression ternaire
    Bonjour ,

    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
     
     
    public class Test {
     
    	/**
             * @param args
             */
    	public static void main(String[] args) {
     
                 Integer FlagErreur = null;
    	Integer FlagMail = null;
    	Integer rep = (FlagErreur != null && FlagErreur == 1 )
    	      ?(FlagMail != null)
                           ?0
                           :1
    	     :(FlagMail != null)
                            ?0
                            :null ; //Si je change par 1 je n'ai pas de NullPointerException
    	 System.out.println(rep);
     
    	}
     
    }
    Résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Exception in thread "main" java.lang.NullPointerException
    	at Test.main(Test.java:15)
    J'attend bien sure qu'il maffiche null
    Quelqu'un aurai une explication ?

    Merci d'avance,
    Cordialement.

  2. #2
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,


    Avant toute chose : ce code est affreux !!!

    Les expressions ternaires c'est déjà pas très lisible, mais en enchainé trois comme cela c'est affreux ! Mais en plus tu y mélanges de l'autoboxing :/

    Un simple if fonctionnerait bien mieux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	final Integer rep;
    	if (FlagErreur != null && FlagErreur == 1) {
    		rep = (FlagMail != null) ? 0 : 1;
    	} else {
    		rep = (FlagMail != null) ? 0 : null;
    	}
    	System.out.println(rep);
    Voir même mieux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    	final Integer rep;
    	if (FlagMail!=null) {
    		rep = 0;
    	} else if (FlagErreur != null && FlagErreur == 1) {
    		rep = 1;
    	} else {
    		rep = null;
    	}
    	System.out.println(rep);




    Maintenant pour revenir à ton problème, il semblerait que cette accumulation d'expression ternaire fasse perdre la boule au compilateur, surtout que tu y mélange de l'autoboxing.

    Explication : une expression ternaire a un type, qui correspond au type de base des deux opérandes.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     condition ? "valeur A" : "valeur B"
    L'expression est de type String, puisque les deux valeurs sont des String :



    Dans ton exemple tu as 3 expressions ternaires.
    Afin de déterminer le type de la première expression, il faut d'abord déterminer des deux sous-expressions :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (FlagMail != null) ? 0 : 1
    De type int

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (FlagMail != null) ? 0 : null
    De type Integer (via autoboxing pour 0).


    Du coup ton expression globale se présente sous cette forme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (FlagMail != null) ? <int> : <Integer>
    Apparemment l'expression ternaire semble privilégié le type natif, et prendra donc le type int. L'Integer de la seconde partie sera donc convertie en int...


    Et bien sûr quand on essaye de convertir un null en int, on obtient une joli NullPointerException !



    Bref deux conseils :
    - Evites les expressions ternaires illisibles.
    - Evites de trop jouer avec l'autoboxing, sauf pour des affectations simples.



    a++

  3. #3
    Membre expérimenté
    Avatar de l4r3nZu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Janvier 2010
    Messages : 154
    Par défaut
    Pour les expression ternaire complexes je suis daccord mais j'utilise un ETL Et c'est soit creer une routine (fonction) ou une expression ternaire . Mon bout de code est pas assez gros pour creer une fonction et à peine un peu trop pour une expression ternaire.

    Merci beaucoup il fallait trouver quand meme ^^

  4. #4
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Dans ce cas il faut tout caster en Integer pour éviter le passage en int :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	Integer rep = (FlagErreur != null && FlagErreur == 1 )
    	      ?(FlagMail != null)
                           ? (Integer)0
                           : (Integer)1
    	     :(FlagMail != null)
                            ? (Integer)0
                            :null ;

    a++

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

Discussions similaires

  1. Problème expression régulières
    Par LEK dans le forum C#
    Réponses: 2
    Dernier message: 18/04/2007, 11h40
  2. Problème Expression conditionnelle
    Par nicolasferraris dans le forum ASP
    Réponses: 6
    Dernier message: 15/03/2007, 09h52
  3. [RegEx] problème expression régulière
    Par H-bil dans le forum Langage
    Réponses: 4
    Dernier message: 13/02/2007, 15h38
  4. Problème expressions régulières
    Par sozie9372 dans le forum Langage
    Réponses: 3
    Dernier message: 07/06/2006, 15h13
  5. Problème expression regulière ??
    Par panaone dans le forum Langage
    Réponses: 5
    Dernier message: 18/08/2005, 13h41

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