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 :

Delta(Canard.java) => Delta(Mare.class)


Sujet :

Langage Java

  1. #1
    Membre averti
    Avatar de Chatanga
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 211
    Points : 346
    Points
    346
    Par défaut Delta(Canard.java) => Delta(Mare.class)
    Mise en place

    Fichier Canard.java

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    public class Canard
    {
    	public static final String CRI = "Coin ! Coin !";
    }
    Fichier Mare.java

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    public class Mare
    {
    	public static void main(String[] arguments) {
    		System.out.println("Le canard dit : " + Canard.CRI);
    	}
    }
    Manipulation

    1) javac Mare.java

    -> Les deux fichiers Java sont compilés.

    2) java Mare

    -> Affiche "Le canard dit : Coin ! Coin !"

    4) Changement de "Coin ! Coin !" en "Miaou !" dans le fichier Canard.java.

    5) javac Canard.java

    -> Seul Canard.java est compilé.

    6) java Mare

    -> Affiche "Le canard dit : Coin ! Coin !"

    7) rm Mare.class

    -> Affiche "Le canard dit : Coin ! Coin !"

    Conclusion :

    La constante CRI n'est visiblement par référencée, mais sa valeur directement "embarquée" dans les classes qui l'utilisent (ici la Mare.java). A ma connaissance, il s'agit du seul cas où une modification dans un fichier *.java se répercute sur d'autres *.class que le sien (ou les siens dans le cas de classes internes).

    Question :

    Existe-t-il d'autres cas de figures et, idéalement, un principe général ?

  2. #2
    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
    quand une variable est static, public, final, le compilateur la considère comme une constante, et pour des raisons de performance, embarque directement la valeur de la constante plutot que de référencer la classe.

    En pratique, peut d'impact comme mentionné puisque, tout bon développeur, fait un clean de son projet avant de faire une release


    Autre cas possible: classe java avec date de modification dans le passé.

    Exemple:

    1) Xxx.java récupéré d'un svn
    3) fait un changement
    4) compile
    5) efface le java et récupère le svn
    6) oublie d'effacer le .class -> on est toujours en binaire à la version modifiée

  3. #3
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,

    Citation Envoyé par tchize_ Voir le message
    quand une variable est static, public, final, le compilateur la considère comme une constante,
    Pas tout à fait. static et public n'ont rien à voir avec cela...

    En plus d'être déclarée final, une constante est définie par trois critères :
    • L'attribut doit correspondre à un type primitif ou au type String.
    • Il doit être initialisé en ligne à la déclaration.
    • Il doit pouvoir être évalué à la compilation.


    Dès lors le compilateur se chargera de remplacer le champ par sa valeur partout où elle se trouve. Il est donc impératif d'éviter d'utiliser des constantes pour des champs qui risque de changer. En particulier dans le cas d'une API tierce...


    Dans les fait on constate surtout cela dans un attribut public static, mais ce n'est pas forcément le cas. Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    public class Canard
    {
    	final String cri = "Coin ! Coin ! Coin !";
     
    	public String getCri() {
    		return cri;
    	}
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public class Mare
    {
    	public static void main(String[] arguments) {
    		System.out.println("Le canard dit : " + new Canard().getCri());
    		System.out.println("Le canard dit : " + new Canard().cri);
    	}
    }
    La première ligne sera toujours correct (car la méthode getCri() est logiquement recompilé en même temps que sa classe ). Par contre la seconde ligne peut rencontrer le même soucis car le compilateur remplace l'accès à l'attribut par la valeur de la constante


    a++

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 14/08/2009, 10h46
  2. retrouver le .java à partir d'un .class
    Par lebreizh dans le forum Langage
    Réponses: 3
    Dernier message: 24/10/2006, 17h12
  3. Réponses: 1
    Dernier message: 14/10/2006, 07h13
  4. Conflit entre java.util.Date et class java.sql.Date
    Par vonitiana dans le forum Langage
    Réponses: 3
    Dernier message: 30/06/2006, 11h43
  5. Parseur XML to Java pour creation de Class
    Par yannick101 dans le forum Format d'échange (XML, JSON...)
    Réponses: 1
    Dernier message: 18/07/2005, 14h20

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