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

Débats sur le développement - Le Best Of Discussion :

[Débat] C++ vs Java


Sujet :

Débats sur le développement - Le Best Of

  1. #1041
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    259
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 259
    Points : 607
    Points
    607
    Par défaut
    Salut, je ne pense pas que l'introspection ait été ajoutée a java pour pallier un manque mais tout simplement parce que ca apporte des fonctionnalités intéréssantes.
    Par exemple un système de plugin en tire parti a merveille, on définit une interface, et on ne connait pas les implémentations. Ces dernières sont ajoutées plus tard et on ne change qu'un fichier de config pour définir l'implémentation que l'on veut utiliser. Cela peut même se faire dynamiquement sans redémarrer.

    Sinon sans rapport avec l'introspection : j'entend partout que les templates c'est bien mieux que les generics. Oui mais en quoi ? J'ai utilisé les 2, mais je n'ai pas une aussi grande expérience du c++ que du java et donc je n'ai pas vu d'avantage décisif aux templates, quelqu'un pourrait il éclairer ma lanterne ?

  2. #1042
    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 kpouer Voir le message
    Sinon sans rapport avec l'introspection : j'entend partout que les templates c'est bien mieux que les generics. Oui mais en quoi ?
    C'est surtout une approche différente :
    • Les templates du C++ représente en faite un "modèle" que le compilateur utilise pour générer du nouveau code. En gros c'est comme s'il faisait un copier-coller + un remplacement de valeur.
      Cela permet beaucoup de chose car les vérifications sont faitent pour chaque type lors de leurs utilisations, mais cela a aussi le défaut de générer une nouvelle classe par type utilisé en paramétrage.
    • Les Generics de Java se basent sur des classes génériques, et en fait le compilateur se charge de vérifier l'utilisation et de cacher les cast. Du coup cela ne génère pas plusieurs versions de la même classe, mais cela a le désavantage de rendre certaines choses impossible (new T() par exemple) puisqu'on ne connait jamais le type en paramétrage...


    J"vais fait un billet un peu plus complet sur le sujet : Les Generics ne sont pas des Templates comme les autres !


    a++

  3. #1043
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    adiGuba > dans le blog tu te trompes. Une méthode peut être template sans que la classe à laquelle elle appartient le soit. Et si la classe est template aussi, la méthode peut en plus l'être également.
    Enfin bon

    D'ailleurs j'ai une question. Est-ce que ce genre de chosess se fait en Java avec les Generics ?

  4. #1044
    Membre confirmé

    Inscrit en
    Août 2007
    Messages
    300
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 300
    Points : 527
    Points
    527
    Par défaut
    adiGuba, tu résumes bien les objectifs initiaux des templates C++, tels qu'ils étaient perçus en 1994 lors de la présentation de la STL. Depuis, le moins qu'on puisse dire, c'est que que les templates C++ se sont révélés formidablement plus puissants que prévu, d'ailleurs à la surprise des spécialistes du langage.
    Citation Envoyé par Bjarne Stroustrup
    generic programming is the area where use of C++ has progressed the furthest relative to the support offered by the language
    Citation Envoyé par Scott Meyer
    My understanding of templates was still at the container-of-T stage, while Barton, Nackman, Stepanov and others were demonstrating that such uses barely scratched the surface of what templates could do.
    Les travaux d'Alexandrescu, Abrahams et Gurtovoy ont popularisé des techniques insoupçonnées à l'époque de la définition des templates. Ces utilisations (quelques exemples ici) montrent la différence avec les Generics de Java et le "duck typing" de Ruby. Les concepts de C++0x devraient étendre ces principes, et aussi mettre un peu d'huile dans les rouages des écritures actuellement utilisées dans la métaprogrammation, qui sont assez peu lisibles il faut le reconnaitre (en particulier les messages d'erreur à la compilation).

    Je ne souhaite pas du tout entrer dans la controverse Java/C++, simplement souligner qu'il y a une différence bien plus grande entre les templates C++ et les Generics de Java qu'indiqué dans le blog (l'instanciation multiple de code n'est qu'un détail sans intérêt vis-à-vis de ce qui est effectivement apporté par les templates en termes de conception).

  5. #1045
    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 Alp Voir le message
    adiGuba > dans le blog tu te trompes. Une méthode peut être template sans que la classe à laquelle elle appartient le soit. Et si la classe est template aussi, la méthode peut en plus l'être également.
    Enfin bon
    Oui cela m'avait été signalé mais je n'avais pas modifié le billet... Il faudrait que je le fasse

    Mais pour moi le principal n'était pas vraiment là : je voulais plutôt mettre le focus sur le fait que malgré une syntaxe proche il ne s'agit pas du tout des mêmes notions...


    Citation Envoyé par Alp Voir le message
    D'ailleurs j'ai une question. Est-ce que ce genre de chosess se fait en Java avec les Generics ?
    Si j'ai bien compris cela permet de générer du code différent selon le type.
    Ce n'est pas possible avec les Generics car on fait complètement abstraction du type.

    Pour quelque chose de similaire j'utiliserais des interface générics...


    Citation Envoyé par ac_wingless Voir le message
    adiGuba, tu résumes bien les objectifs initiaux des templates C++, tels qu'ils étaient perçus en 1994 lors de la présentation de la STL. Depuis, le moins qu'on puisse dire, c'est que que les templates C++ se sont révélés formidablement plus puissants que prévus, d'ailleurs à la surprise des spécialistes du langage.
    Mon C++ est assez rouillé en effet

    Par contre vous me titiller avec ce principe de "concepts"... il faudra que j'y jettes un coup d'oeil lorsque j'aurais un peu de temps


    a++

  6. #1046
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    On a un projet d'article en cours sur les concepts de C++0x.
    Fais une recherche dans le forum C++ t'auras quelques éléments

  7. #1047
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Points : 9 818
    Points
    9 818
    Par défaut
    Citation Envoyé par Alp Voir le message
    D'ailleurs j'ai une question. Est-ce que ce genre de chosess se fait en Java avec les Generics ?
    Quoi précisement ?

    Les classes de policies se font mais pas de la même manière.

    Par contre, il n'est pas possible d'avoir un moment un code qui ressemble à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UneClasse.unType truc;
    Mais il y a d'autres manières de faire suivant ce que tu veux exactement faire.

  8. #1048
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    Le fait est que pas mal des techniques avancées d'utilisation des templates permettent d'avoir un semblant de réflexivité. Enfin, on peut décrire une classe à la compilation, en tout cas.
    Et il me semble bien qu'en Java tout est déjà pré-maché

    Après, pour les policies, l'application la plus connue est celle issue du bouquin d'Alexandrescu : La bibliothèque Loki.

  9. #1049
    Membre expérimenté Avatar de davcha
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    1 258
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 258
    Points : 1 539
    Points
    1 539
    Par défaut
    Citation Envoyé par LLB Voir le message
    Java et C# ont choisi d'imposer le modèle objet. Je trouve ça dommage d'imposer ce paradigme [...]
    En quoi est-ce dommage, exactement ?

    Je veux dire, Hashkell impose un paradigme spécifique aussi, tout comme C/C++, ainsi que tous les autres langages.
    Alors pourquoi est-ce dommage que Java/C# imposent le modèle objet ?...

    Au final, plutôt que d'être imposé par un langage le choix du paradigme ne reste-t-il pas un choix de l'équipe de développement, du client et/ou du chef de projet... ?
    Je veux dire, si ton client, chef de projet, ton équipe et/ou toi-même ne souhaitent pas développer en objet, rien ne vous impose d'utiliser un langage objet.

    Je vois un cas où ça peut être dommage : le cas où tu as envie d'utiliser une technologie qui n'est disponible que dans un langage spécifique, mais que tu souhaites utiliser un autre langage ou paradigme que celui imposé par le langage en question (par exemple wpf supportant mal c++/cli).

    Citation Envoyé par LLB Voir le message
    Oui, les templates sont bien plus puissants que les generics.
    A noter que les templates en tant que meta-programmation n'ont pas forcément un intérêt phénoménal en java ou en c#, puisque ces langages permettent de générer du code, typé, lors de l'exécution.

  10. #1050
    LLB
    LLB est déconnecté
    Membre expérimenté
    Inscrit en
    Mars 2002
    Messages
    968
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 968
    Points : 1 412
    Points
    1 412
    Par défaut
    Citation Envoyé par davcha Voir le message
    En quoi est-ce dommage, exactement ?
    En fonction du problème, certaines approches sont beaucoup plus efficaces que d'autres. Je préfère quand je peux choisir la vision des choses à adopter, sans avoir à changer de langage (ce qui est rarement pratique).

    Citation Envoyé par davcha Voir le message
    A noter que les templates en tant que meta-programmation n'ont pas forcément un intérêt phénoménal en java ou en c#, puisque ces langages permettent de générer du code, typé, lors de l'exécution.
    Le système de templates est turing-complet et reste plus puissant que l'approche des generics. Il permet aussi plus de généricité et n'est pas restreint par les interfaces. Il a aussi ses inconvénients, mais j'imagine que tout cela a été détaillé au cours des 70 pages de discussion.

  11. #1051
    Membre expérimenté Avatar de davcha
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    1 258
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 258
    Points : 1 539
    Points
    1 539
    Par défaut
    Citation Envoyé par LLB Voir le message
    En fonction du problème, certaines approches sont beaucoup plus efficaces que d'autres. Je préfère quand je peux choisir la vision des choses à adopter, sans avoir à changer de langage (ce qui est rarement pratique).
    D'accord, cite-moi un exemple de solution plus efficace en C++ qui ne soit pas réalisable ou pas aussi efficace en Java/C# à cause du paradigme de ces langages, alors.

    Citation Envoyé par LLB
    Le système de templates est turing-complet et reste plus puissant que l'approche des generics. Il permet aussi plus de généricité et n'est pas restreint par les interfaces. Il a aussi ses inconvénients, mais j'imagine que tout cela a été détaillé au cours des 70 pages de discussion.
    Je ne parlais pas des generics, ici.
    Je pensais plus à l'AOP et, en ce qui concerne C# en tout cas (je ne sais pas si Java a un équivalent, mais ça m'étonnerait pas) de la possibilité de générer du code MSIL au runtime.

  12. #1052
    LLB
    LLB est déconnecté
    Membre expérimenté
    Inscrit en
    Mars 2002
    Messages
    968
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 968
    Points : 1 412
    Points
    1 412
    Par défaut
    Citation Envoyé par davcha Voir le message
    D'accord, cite-moi un exemple de solution plus efficace en C++ qui ne soit pas réalisable ou pas aussi efficace en Java/C# à cause du paradigme de ces langages, alors.
    Mon propos était assez général. Dans certains problèmes, on peut par exemple préférer un paradigme fonctionnel, logique ou autre. Ce n'est pas une question de faisabilité (!), ni de performances à l'exécution : c'est une question de conception et d'approche du problème. Je suis également un peu déçu par C++ sur ce point, aussi vaut-il mieux ne pas s'y attarder dans ce thread.

    Dans certains cas, on peut ne pas vouloir de classe, or Java nous l'impose. Je trouve ça juste "dommage", mais ce n'est pas vraiment un problème, en soi.

    Mais si tu veux quelque chose qui n'est pas faisable en Java, regarde du côté des templates, de la généricité et de la méta-programmation. Comme je l'ai dit, je suis convaincu que tout a déjà été abordé et je n'ai pas envie de m'étendre.

  13. #1053
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    A ce sujet, lire "Modern C++ Design" et "C++ Template Metaprogramming" (2 oeuvres qui couvrent assez bien la programmation générique et la conception générique).

  14. #1054
    Membre expérimenté Avatar de davcha
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    1 258
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 258
    Points : 1 539
    Points
    1 539
    Par défaut
    Citation Envoyé par LLB Voir le message
    Mais si tu veux quelque chose qui n'est pas faisable en Java, regarde du côté des templates, de la généricité et de la méta-programmation. Comme je l'ai dit, je suis convaincu que tout a déjà été abordé et je n'ai pas envie de m'étendre.
    Vous avez parlé de l'AOP (AspectJ, Postsharp...) et des possibilités offertes par MSIL (dynamicmethod, tout ça...) ?

    Pour ce qui est du paradigme fonctionnel, logique ou autre préférable dans certains cas, je suis tout à fait d'accord. J'ai juste du mal à voir exactement où se situe cette question quand on compare c/c++ et java/c#

  15. #1055
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 282
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 282
    Points : 11 036
    Points
    11 036
    Par défaut
    Dans une moindre mesure le C++ les supporte.

  16. #1056
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    Comme pour pas mal de choses, la souplesse du C++ permet de "simuler" ou encore "approcher" des techniques/paradigmes de programmation qui ne sont à l'origine pas fait pour le C++.

  17. #1057
    Membre chevronné

    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Novembre 2006
    Messages
    1 252
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 252
    Points : 1 954
    Points
    1 954
    Par défaut
    Citation Envoyé par davcha Voir le message
    Je pensais plus à l'AOP et, en ce qui concerne C# en tout cas (je ne sais pas si Java a un équivalent, mais ça m'étonnerait pas) de la possibilité de générer du code MSIL au runtime.
    En java, l'application des aspects peuvent se faire dynamiquement, avec donc génération du bytecode au runtime.

  18. #1058
    Expert éminent sénior
    Avatar de Mat.M
    Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2006
    Messages
    8 506
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 8 506
    Points : 20 792
    Points
    20 792
    Par défaut
    Donc pour conclure
    Java=C++ avec Garbage Collector + Bibliothèques de code et fonctions

  19. #1059
    Alp
    Alp est déconnecté
    Expert éminent sénior

    Avatar de Alp
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    8 575
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Juin 2005
    Messages : 8 575
    Points : 11 861
    Points
    11 861
    Par défaut
    Qu'est-ce qu'il ne faut pas lire ...

  20. #1060
    Membre expérimenté Avatar de davcha
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    1 258
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 1 258
    Points : 1 539
    Points
    1 539
    Par défaut
    Donc.... le C++, c'est de l'assembleur qui s'exécute dans une machine virtuelle ?...

Discussions similaires

  1. [Débat] Technologie .NET vs JAVA
    Par neo.51 dans le forum Débats sur le développement - Le Best Of
    Réponses: 1047
    Dernier message: 14/01/2019, 17h15
  2. [Débat] .NET vs JAVA/J2EE
    Par tssi555 dans le forum VB.NET
    Réponses: 5
    Dernier message: 10/12/2008, 08h54

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