Linus Torvalds : le "C++ est un langage horrible"
En justifiant le choix du C pour le système de gestion de version Git
Le 2011-11-08 14:55:19, par Idelways, Expert éminent sénior
Cet article n'est pas proprement né d'une nouveauté, mais fait écho à une tempête que soulève la découverte d'un email vieux de quatre ans.
Des « cyberspéléologues » ont sorti des méandres sournois des archives du Net un email fort polémique. Son auteur n'est autre que Linus Torvalds, le célèbre créateur du noyau Linux, tout aussi connu parmi les développeurs pour avoir initié le projet Git, le système de gestion de version (très) à la mode.
En réponse à un contributeur qui s'interrogeait en 2007 sur les raisons qui ont conduit au choix du C (plutôt que du C++), Torvalds s'en est donner à coeur joie pour avouer son désamour au C++ qu'il qualifie d’« horrible langage ».
Il est vrai que son interlocuteur n'a pas dû tourner deux fois les doigts sur son clavier avant de qualifier l'argument de portabilité d'un délicat « bullshit » (foutaise), mais l'avis de Torvalds est tellement tranché — sur le langage, mais surtout sur ses développeurs — qu'il semblait attendre une telle opportunité pour l'étaler.
« C++ est un langage horrible. Ce qui le rend d'autant plus horrible est le fait que beaucoup de programmeurs “substandard” l'utilisent, au point qu'il est nettement plus facile de générer de la merde totale et absolue avec », sic.
Le choix du langage de Git, avoue le développeur, n'est là que pour « garder les programmeurs C++ loin, c’est en soi, un énorme argument en faveur de l'utilisation du C », surenchérit-il.
Après un autre paragraphe tout aussi scatologique à l'encontre des développeurs C++, Torvalds passe aux arguments techniques. « C++ entraîne à des choix de conception très très mauvais. Vous commencez invariablement par utiliser les fonctionnalités “sympas” de la librairie standard du langage comme STL, Boost et autres conneries totales et absolues, ça peut aider votre programme, mais ça engendre : »
Il énumère, d'abord : « la souffrance infinie quand ça ne marche pas ». Sur ce point, il remet en cause la stabilité et la portabilité de la bibliothèque standard et « surtout de Boost ». Puis de s'attaquer à « l'abstraction inefficace des modèles de programmations, où, deux ans plus tard, vous vous rendez compte que certaines abstractions n'étaient pas très efficaces, alors que maintenant, tout votre code dépend de ces beaux modèles objets, et vous ne pouvez corriger tout ça sans réécrire votre application ».
À se demander si Torvalds n'a pas plutôt une dent contre toute la programmation orientée objet pour les usages de niveau système. « La seule manière de faire du C++ bien, efficace, de niveau système et portable revient à vous limitez à tous les trucs que sont à la base disponible en C », déclare-t-il avec force de conviction.
Torvalds explique par la suite et en substance que l'efficacité est le premier objectif à atteindre sur des projets tels que Git, et en prime « emmerder les personnes incapables de le comprendre », et de comprendre « les problèmes de bas niveau ».
Peu accueillant sur son projet, il invite les développeurs désireux d'écrire un CVS en C++ d'aller voir du côté de Monotone, un projet qui s'enorgueillirait d'après lui de décisions de conceptions « reluisantes pour les gars des sciences informatiques », mais qui conduisent finalement à « une pagaille horrible et non-maintenable ».
Nourrie par une forte intensité dans le verbe et d'une perceptible volonté de blesser, une véritable polémique est née entre les partisans du langage. La rivalité entre les deux camps n'est pas nouvelle, mais l'intervention aussi virulente d'un personnage emblématique ne contribue certainement pas à faire avancer sereinement le débat.
Il n'empêche que des arguments techniques sont là, et nous vous invitons à y répondre objectivement.
Source : l'email original de Torvalds
Voir aussi sur C++ :
Cours et tutoriels C++.
La FAQ C++.
Le Forum C++.
Et vous ?
Que pensez-vous de la position de Linux Torvalds et de ses arguments ?
Des « cyberspéléologues » ont sorti des méandres sournois des archives du Net un email fort polémique. Son auteur n'est autre que Linus Torvalds, le célèbre créateur du noyau Linux, tout aussi connu parmi les développeurs pour avoir initié le projet Git, le système de gestion de version (très) à la mode.
En réponse à un contributeur qui s'interrogeait en 2007 sur les raisons qui ont conduit au choix du C (plutôt que du C++), Torvalds s'en est donner à coeur joie pour avouer son désamour au C++ qu'il qualifie d’« horrible langage ».
Il est vrai que son interlocuteur n'a pas dû tourner deux fois les doigts sur son clavier avant de qualifier l'argument de portabilité d'un délicat « bullshit » (foutaise), mais l'avis de Torvalds est tellement tranché — sur le langage, mais surtout sur ses développeurs — qu'il semblait attendre une telle opportunité pour l'étaler.
« C++ est un langage horrible. Ce qui le rend d'autant plus horrible est le fait que beaucoup de programmeurs “substandard” l'utilisent, au point qu'il est nettement plus facile de générer de la merde totale et absolue avec », sic.
Le choix du langage de Git, avoue le développeur, n'est là que pour « garder les programmeurs C++ loin, c’est en soi, un énorme argument en faveur de l'utilisation du C », surenchérit-il.
Après un autre paragraphe tout aussi scatologique à l'encontre des développeurs C++, Torvalds passe aux arguments techniques. « C++ entraîne à des choix de conception très très mauvais. Vous commencez invariablement par utiliser les fonctionnalités “sympas” de la librairie standard du langage comme STL, Boost et autres conneries totales et absolues, ça peut aider votre programme, mais ça engendre : »
Il énumère, d'abord : « la souffrance infinie quand ça ne marche pas ». Sur ce point, il remet en cause la stabilité et la portabilité de la bibliothèque standard et « surtout de Boost ». Puis de s'attaquer à « l'abstraction inefficace des modèles de programmations, où, deux ans plus tard, vous vous rendez compte que certaines abstractions n'étaient pas très efficaces, alors que maintenant, tout votre code dépend de ces beaux modèles objets, et vous ne pouvez corriger tout ça sans réécrire votre application ».
À se demander si Torvalds n'a pas plutôt une dent contre toute la programmation orientée objet pour les usages de niveau système. « La seule manière de faire du C++ bien, efficace, de niveau système et portable revient à vous limitez à tous les trucs que sont à la base disponible en C », déclare-t-il avec force de conviction.
Torvalds explique par la suite et en substance que l'efficacité est le premier objectif à atteindre sur des projets tels que Git, et en prime « emmerder les personnes incapables de le comprendre », et de comprendre « les problèmes de bas niveau ».
Peu accueillant sur son projet, il invite les développeurs désireux d'écrire un CVS en C++ d'aller voir du côté de Monotone, un projet qui s'enorgueillirait d'après lui de décisions de conceptions « reluisantes pour les gars des sciences informatiques », mais qui conduisent finalement à « une pagaille horrible et non-maintenable ».
Nourrie par une forte intensité dans le verbe et d'une perceptible volonté de blesser, une véritable polémique est née entre les partisans du langage. La rivalité entre les deux camps n'est pas nouvelle, mais l'intervention aussi virulente d'un personnage emblématique ne contribue certainement pas à faire avancer sereinement le débat.
Il n'empêche que des arguments techniques sont là, et nous vous invitons à y répondre objectivement.
Source : l'email original de Torvalds
Voir aussi sur C++ :
Et vous ?
-
zeyr2mejetremMembre chevronnéHormis le débat sempiternel C/C++ Procédural/Objet Sel/Poivre Fromage/Dessert,
Je trouve que le fait de ressortir un vieil email privé moisi datant d'il y a 4 ans et sorti de son contexte pour faire de la news, c'est vraiment limite.
Linus Thorvalds n'est qu'un homme comme les autres.
Qui nous dit qu'il n'en était pas à son 250ème email sur le thème "Pourquoi Git c'est du C? le C ça pue !!" et qu'il n'a pas pété un câble en renvoyant le bonhomme dans ses 22 en lui disant "Foutez moi la paix avec votre langage de merde, vous voulez que je vous dise, Git est en C pour pas voir vos tronches dans le projet car vous me les brisez menu !!"
Cela n'est jamais arrivé à personne de sortir un mail salé avec une argumentation un peu bancale tout simplement parce que le gars de l'autre côté vous casse les pieds depuis longtemps et que vous avez les nerfs ?
La seule différence, c'est que parce qu'il s'appelle Linus Thorvald on publie son mail 4 ans plus tard.
Ca c'est de la news de paparazzi et je dois avouer que je suis assez déçu de voir ça sur ce site que j'estime.le 08/11/2011 à 17:42 -
zeyr2mejetremMembre chevronnéJe n'ai aucun doute sur l'intégrité de l'équipe de rédaction.
Ressortir cette histoire n'est pas une actualité dans le sens strict du terme, mais notre but n'est pas seulement de suivre les news, mais aussi de lancer des débats et parler de ce qui fait le buzz (même les buzz "dormants" pendant des années)
Il est toutefois vrai que cette histoire ressort pour la deuxième fois. Mais la première n'était pas traitée en article en bonne et due forme et n'avait pas été annoncée sur les portails. D'où la décision de remonter ce sujet.
Cordialement
Idelways
Après c'est une opinion qui m'est propre mais que je pense partagée par pas mal de personnes.le 08/11/2011 à 18:10 -
tomlevRédacteur/Modérateur« C++ est un langage horrible. Ce qui le rend d'autant plus horrible est le fait que beaucoup de programmeurs “substandard” l'utilisent, au point où il est nettement nettement plus facile de générer de la merde totale et absolue avec »le 08/11/2011 à 18:04
-
Nathanael MarchandRédacteurle 08/11/2011 à 22:46
-
Joel FMembre chevronnédepuis quand un troll fait une actualité ?le 08/11/2011 à 17:09
-
oodiniMembre émériteTiens, il ne parle pas pas des mauvais développeurs C qui font des choses horribles avec les pointeurs.
D'ailleurs, ceux qui font des choses horribles en C++ sont généralement des gens qui ont gardé des habitudes du C.le 08/11/2011 à 15:20 -
Emmanuel DelogetExpert confirméComme le C. En même temps, une norme sert à mettre tout le monde d'accord. Considérer comme Digital Mars que le compilateur c'est la norme, ça n'est rien de plus qu'enfermer les utilisateurs chez un vendeur particulier. Le D de DM , étant non standardisé, évolue peut-être plus vite que le C++, mais au prix d'avoir une offre très faible en termes d'outils, tou en réussissant le tour de force de faire en sorte que cette offre soit fractionnée (à la marge, le compilateur D de GNU ne compile pas le même D que MD, et les deux n'évoluent pas à la même vitesse).
- Langage d'une grande complexité devant une apparence simple
Ce sui ne veut rien dire, à moins que tu ne sois capable de définir "défi moderne"
Moins d'API, c'est évident. Le langage est aussi moins compris, ses cas particuliers n'ont pas été étudiés, et personne ne sait ce que le compilateur, dans deux ans, fera du code actuel.
Pas de standardisation (qu'elle soit de fait ou non, comme Java) = danger pour les utilisateurs. Une entreprise ne peux pas se satisfaire d'un tel état des choses.le 08/11/2011 à 18:06 -
ArzarMembre émériteEncore !??mais fait écho à une tempête que soulève la découverte d'un email vieux de quatre ans.
http://www.developpez.net/forums/d75...lds-naime-cpp/
Discussion dont le troisième message est :Envoyé par fcharton le 08/11/2011 à 15:42 -
Aurelien.Regat-BarrelExpert éminent séniorDans le genre avis tranché, y'a celui-là aussi qui est célèbre :
It's terrible. Everyone is using it, and they don't realize how bad it is. And the Linux people will just stick with it and add to it rather than stepping back and saying, 'This is garbage and we should fix it.'
Les chiens aboient, mais la caravane passe!le 08/11/2011 à 17:02 -
oodiniMembre émériteExtrait de Wikipedia :
Le magazine PC World nous apprend que « quand on lui a demandé pourquoi il avait appelé son logiciel « git », qui est à peu près l'équivalent de « connard » en argot anglais, Linus Torvalds a répondu « je ne suis qu'un égocentrique, donc j'appelle tous mes projets d'après ma propre personne. D'abord Linux, puis Git. »
Ça donne une idée du personnage. :-)le 08/11/2011 à 18:07