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

Java Discussion :

Java 7 : petit état des lieux du projet Lambda...


Sujet :

Java

  1. #1
    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 Java 7 : petit état des lieux du projet Lambda...


    En fin d'année dernière, le report de Java 7 laissait envisagé l'intégration des closures. Cela a donné naissance au projet Lambda dont l'objectif était de regrouper les différents travaux afin d'en sortir une spécification claire et fonctionnelle quitte à se passer de certain "power-concept".

    Il en ressort une proposition d'expressions Lambda relativement allégé vis à vis des multiples et très complètes propositions de closures qui ont pu être proposé par le passé. Mais cela s'accompagne également de nouveaux concepts fort intéressants (Exception Transparency, Method References, Defender Methods).

    Voyons voir de quoi il en retourne...




    » Lire la suite!

    Billet original publié sur les blogs de developpez.com...

  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
    merci pour ce billet adiguba, c'est toujours un plaisir à lire.

    Je craint avec ces nouvelle facilité qu'on commence à retrouver du code moche à la pelle, encore plus qu'actuellement. On v voir des programmeur utiliser les defendeur methode pour faire du veritable héritage multiple, avec des interface donc aucune méthode ne devra être implémentée . Un peux comme des abstract, sauf qu'on pourrait "hériter" de plusieurs.


    Aussi, comme les defenders methods seront "injectées" dans les classes implémentant de manière incomplète l'interface, comme le securtiymanager va empecher ces defenders methods de tripatouiller l'objet en question si l'accès à celui-ci est supposé restreint pour des raisons X ou Y.


    Enfin, une question sur ce bout de code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comparator<String> compare = String#compareToIgnoreCase(String);
    Le Comparator prend deux paramètre, je ne vois qu'un seul paramètre dans la référence (le deuxième String). Je suppose que le premier paramètre du Comparator est utilisé comme instance sur laquelle la méthode doit être appelée. Comme les distinguer? Suis-je obligé de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comparator<String> compare = #(a, b){a.compareToIgnoreCase(b)}
    oui y a-t-il un moyen plus direct, du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comparator<String> compare = a#(a, b)compareToIgnoreCase(b){
    La différence étant que dans le premier cas, je crée une méthode anonyme, dans le deuxième cas, j'utilise directement la référence à une méthode existante....

    Enfin, aussi, avec les Methode référence utilisant une isntance, comment le cas du null sera-t-il traité? Exception? Si oui, l'implémentation d'un comparator en passant directement une référence sera plus sujette à erreur....


    Et last but not least. On a une date de sortie? Parce que sur le site de java.net ils parlent d'une sortie pour 2008 qui a été repoussée en janvier 2009? Faudra leur offrir un calendrier

  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
    Citation Envoyé par tchize_ Voir le message
    Je craint avec ces nouvelle facilité qu'on commence à retrouver du code moche à la pelle, encore plus qu'actuellement. On v voir des programmeur utiliser les defendeur methode pour faire du veritable héritage multiple, avec des interface donc aucune méthode ne devra être implémentée . Un peux comme des abstract, sauf qu'on pourrait "hériter" de plusieurs.
    Quel que soit la fonctionnalité, il y a toujours des solutions pour faire un truc sale


    Citation Envoyé par tchize_ Voir le message
    Aussi, comme les defenders methods seront "injectées" dans les classes implémentant de manière incomplète l'interface, comme le securtiymanager va empecher ces defenders methods de tripatouiller l'objet en question si l'accès à celui-ci est supposé restreint pour des raisons X ou Y.
    Les méthodes d'extension reste des méthodes static classique, avec les mêmes restrictions. Le code injecté devrait se contenter d'appeler la méthode static. Par exemple pour un éventuelle sort() dans List cela générerait une méthode comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public void sort() {
         Collections.sort(this);
    }
    Il n'y a aucun tripatouillage


    Citation Envoyé par tchize_ Voir le message
    Enfin, une question sur ce bout de code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comparator<String> compare = String#compareToIgnoreCase(String);
    Le Comparator prend deux paramètre, je ne vois qu'un seul paramètre dans la référence (le deuxième String).
    Il s'agit ici d'une référence sur une méthode d'instance, donc l'instance est rajouté en premier paramètre ce qui génère une méthode avec deux paramètre...

    Citation Envoyé par tchize_ Voir le message
    Je suppose que le premier paramètre du Comparator est utilisé comme instance sur laquelle la méthode doit être appelée. Comme les distinguer? Suis-je obligé de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comparator<String> compare = #(a, b){a.compareToIgnoreCase(b)}
    oui y a-t-il un moyen plus direct, du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Comparator<String> compare = a#(a, b)compareToIgnoreCase(b){
    La différence étant que dans le premier cas, je crée une méthode anonyme, dans le deuxième cas, j'utilise directement la référence à une méthode existante....
    Attention car là tu mélanges "Expressions Lambda" et "Method References" !

    Pour les "Method Reférences" sur une méthode d'instance tu as deux possibilités :
    • Soit tu références une méthode de manière static, et dans ce cas un paramètre initial est automatiquement rajouté à la signature :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      String#compareToIgnoreCase(String); // signature : int(String,String)
    • Soit tu références la méthode via une instance, et là tu appeleras automatiquement la méthode sur l'instance indiqué (pas d'ajout de paramètre) :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      String text = "hello";
      text#compareToIgnoreCase(String); // signature : int(String)


    [quote=tchize_;5431577]Enfin, aussi, avec les Methode référence utilisant une isntance, comment le cas du null sera-t-il traité? Exception?
    Un NPE me semble tout indiqué oui...

    Citation Envoyé par tchize_ Voir le message
    Si oui, l'implémentation d'un comparator en passant directement une référence sera plus sujette à erreur....
    Je ne pense pas que les Comparator gèrent les valeurs nulles... mais oui les valeurs nulle devront être géré si on les utilisent (comme toujours en fait).


    Citation Envoyé par tchize_ Voir le message
    Et last but not least. On a une date de sortie? Parce que sur le site de java.net ils parlent d'une sortie pour 2008 qui a été repoussée en janvier 2009? Faudra leur offrir un calendrier
    Alors là aucune idée !
    Les derniers plannings prévoyait une version finale pour septembre mais je doute que ce soit le cas. Le build "feature complete" aurait dû sortir en mai... mais on n'y est pas encore.

    Je pense qu'il faudra attendre JavaOne pour avoir plus de news là dessus.


    a++

Discussions similaires

  1. État des lieux sur l'utilisation du HTML5 par l'équipe de Kendo UI
    Par vermine dans le forum Balisage (X)HTML et validation W3C
    Réponses: 19
    Dernier message: 11/11/2012, 13h38
  2. État des lieux de l'Open Source Business Intelligence
    Par ygrim dans le forum Approche théorique du décisionnel
    Réponses: 15
    Dernier message: 30/07/2008, 17h50
  3. Création Compo graphique : état des lieux
    Par qi130 dans le forum Composants VCL
    Réponses: 3
    Dernier message: 28/04/2006, 14h26

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