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

C++ Discussion :

[idiom/hack] : Named operators


Sujet :

C++

  1. #1
    Rédacteur

    Avatar de Davidbrcz
    Homme Profil pro
    Ing Supaéro - Doctorant ONERA
    Inscrit en
    Juin 2006
    Messages
    2 307
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ing Supaéro - Doctorant ONERA

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 307
    Points : 4 732
    Points
    4 732
    Par défaut [idiom/hack] : Named operators
    Salut.

    Je viens de tomber par le plus grand des hasards sur cette page : named operators.

    Il y a tous les détails sur la page, et je préfère juste poster les exemples qui sont parlant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    auto result = "Hello" <repeat> 3 <join> ", "; std::cout << result << '\n';
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int x = 42; int y = 23; auto z = x <divmod> y; // calculates { x / y, x % y }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    vector<int> vec{ 1, 2, 3 }; vec <append>= 4; // same as: vec = vec <append> 4;
    Que pensez vous de cette approche ?
    Peut elle améliorer l’expressivité du code selon vous ?
    "Never use brute force in fighting an exponential." (Andrei Alexandrescu)

    Mes articles dont Conseils divers sur le C++
    Une très bonne doc sur le C++ (en) Why linux is better (fr)

  2. #2
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 275
    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 275
    Points : 10 985
    Points
    10 985
    Par défaut
    C'est rigolo, mais je crains que cela trop alien pour pouvoir le proposer sur un projet maintenu par plusieurs personnes.
    À la limite, une bibliothèque pourrait volontairement proposer ce genre d'interface à ses utilisateurs.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

  3. #3
    Rédacteur

    Avatar de Davidbrcz
    Homme Profil pro
    Ing Supaéro - Doctorant ONERA
    Inscrit en
    Juin 2006
    Messages
    2 307
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ing Supaéro - Doctorant ONERA

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 307
    Points : 4 732
    Points
    4 732
    Par défaut
    Citation Envoyé par Luc Hermitte Voir le message
    C'est rigolo, mais je crains que cela trop alien pour pouvoir le proposer sur un projet maintenu par plusieurs personnes.
    À la limite, une bibliothèque pourrait volontairement proposer ce genre d'interface à ses utilisateurs.
    C'est vrai que cest deroutant, surtout que ya pas de macro ou d'autres trucs wtf.

    Mais dans le cadre de la création de bibliothèques, tu peux gagner beaucoup en expressivité en complément des opérations plus classiques .
    "Never use brute force in fighting an exponential." (Andrei Alexandrescu)

    Mes articles dont Conseils divers sur le C++
    Une très bonne doc sur le C++ (en) Why linux is better (fr)

  4. #4
    Membre expert
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    1 415
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 1 415
    Points : 3 156
    Points
    3 156
    Par défaut
    L'idée est intéressante.

    C'est dommage d'avoir un symbole instancié dans le scope pour servir d'"objet intermédiaire" comme expliqué alors que fonctionnellement, ça ne sert qu'à la compilation. On peut peut-être ruser avec des const_expr mais je suis pas sûr que ça soit aussi bon qu'un appel de fonction au niveau du code généré.
    Find me on github

  5. #5
    Membre régulier
    Homme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2006
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Transports

    Informations forums :
    Inscription : Octobre 2006
    Messages : 48
    Points : 97
    Points
    97
    Par défaut
    @jblecanard : le compilateur sait inliner des foncteurs de sorte qu'il n'y ait pas de trace de l'objet dans le code généré. Les foncteurs sans état sont depuis le début (depuis la STL ? avant ?) un hack du C++ permettant de transmettre un type plutôt qu'un pointeur de fonction justement pour permettre au compilateur d'inliner le code correspondant. Donc je ne pense pas que ce soit réellement un problème si l'on compile avec optimisation au max.

    Après on devrait pouvoir faire la même chose avec des expressions templates et des string template (possible avec un hack assez furieux) mais la pour le coup bonjour les logs de compilation en cas d'erreur

    Edit:
    J'oublie de donner mon avis sur le sujet.
    Pour répondre à la question, je pense que le C++ manque cruellement de simplicité d'utilisation. Dés que l'on cherche à améliorer la lisibilité du code en créant/utilisant des bibliothèques DSEL on se retrouve avec du boost et template à gogo (proto ? phoenix ? spirit ? ublas ?).
    J'aime boost et j'aime les templates d'une façon générale mais sans vouloir remettre en cause la qualité des bibliothèques de boost, je trouve que le C++ manque d'API simple et efficace et évitant au maximum les logs de compilation interminables en cas d'erreur. Le vrai problème avec ce genre de hack simple, c'est qu'il est trop simple pour se démocratiser en C++.

    Il serait temps que le C++ évolue encore vers plus de simplicité :
    - A quand les modules ?
    - A quand des bibliothèques "python-like" en C++ ?
    - A quand les concepts ?

  6. #6
    Rédacteur

    Avatar de Davidbrcz
    Homme Profil pro
    Ing Supaéro - Doctorant ONERA
    Inscrit en
    Juin 2006
    Messages
    2 307
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ing Supaéro - Doctorant ONERA

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 307
    Points : 4 732
    Points
    4 732
    Par défaut
    Après on devrait pouvoir faire la même chose avec des expressions templates et des string template (possible avec un hack assez furieux) mais la pour le coup bonjour les logs de compilation en cas d'erreur
    Tu es libre d’améliorer la chose.


    Pour répondre à la question, je pense que le C++ manque cruellement de simplicité d'utilisation. Dés que l'on cherche à améliorer la lisibilité du code en créant/utilisant des bibliothèques DSEL on se retrouve avec du boost et template à gogo (proto ? phoenix ? spirit ? ublas ?).
    J'aime boost et j'aime les templates d'une façon générale mais sans vouloir remettre en cause la qualité des bibliothèques de boost, je trouve que le C++ manque d'API simple et efficace et évitant au maximum les logs de compilation interminables en cas d'erreur. Le vrai problème avec ce genre de hack simple, c'est qu'il est trop simple pour se démocratiser en C++.
    Je suis bien d'accord. Plus le temps passe, plus le langage s’enrichit (et se complexifie !). Et mon ressenti global est qu'on peut faire des choses vraiment géniales, mais que les fondations sont des méandres de complexité.


    - A quand les modules ?
    Je suis pas sur de ce que les modules veulent recouvrir. PCH généralisés? Auto génération des headers ?

    Ca simplifiait le dev, et encore, je suis pas convaincu par les fichiers uniques de Java. Avoir le header permet de connaitre directement ce que fait la classe.


    - A quand des bibliothèques "python-like" en C++ ?
    Je connais pas, tu peux détailler ?
    - A quand les concepts ?
    La réponse ici : http://www.cs.ox.ac.uk/ralf.hinze/WG...des/bjarne.pdf
    "Never use brute force in fighting an exponential." (Andrei Alexandrescu)

    Mes articles dont Conseils divers sur le C++
    Une très bonne doc sur le C++ (en) Why linux is better (fr)

  7. #7
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Décembre 2010
    Messages
    734
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 734
    Points : 1 475
    Points
    1 475
    Par défaut
    Citation Envoyé par Davidbrcz Voir le message
    Ca simplifiait le dev, et encore, je suis pas convaincu par les fichiers uniques de Java.
    Java PERMET de définir une classe en un seul fichier, C++ aussi.
    Mais une bonne conception java inclus des interfaces (ou à la rigueur des classes abstraites) pour définir l'interface des classes.
    Et bien travailler en C++ implique de définir des headers...

  8. #8
    Membre émérite

    Inscrit en
    Mai 2008
    Messages
    1 014
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 1 014
    Points : 2 252
    Points
    2 252
    Par défaut
    Citation Envoyé par Davidbrcz Voir le message
    - A quand les concepts ?
    La réponse ici : http://www.cs.ox.ac.uk/ralf.hinze/WG...des/bjarne.pdf
    Encore plus récent, ici : http://www.open-std.org/jtc1/sc22/wg...2013/n3819.pdf
    C'est sorti la semaine dernière, c'est la première spécification disponible pour les concept-lite.

    Sinon, pour les named operators, je trouve le hack très amusant mais jamais je n'irais utiliser ce genre de bidouille dans du code de production.

  9. #9
    Membre expert
    Avatar de Klaim
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Août 2004
    Messages
    1 717
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 1 717
    Points : 3 344
    Points
    3 344
    Par défaut
    De meme si je devais utiliser ce hack ca serait pour une bibliotheque specifique, la ou j'envisagerai un EDSL.

Discussions similaires

  1. Réponses: 7
    Dernier message: 13/11/2009, 17h00
  2. No operation name specified!
    Par Mr.ux dans le forum Services Web
    Réponses: 3
    Dernier message: 10/10/2008, 14h15
  3. [XSL] insérer une balise <a name>
    Par guibong dans le forum XMLRAD
    Réponses: 2
    Dernier message: 01/08/2003, 15h04
  4. TXMLModule.create - name = resource not found
    Par pram dans le forum XMLRAD
    Réponses: 2
    Dernier message: 04/03/2003, 10h54
  5. naming service
    Par manuel dans le forum CORBA
    Réponses: 6
    Dernier message: 09/12/2002, 17h43

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