`
妖妖然
  • 浏览: 46615 次
  • 性别: Icon_minigender_2
  • 来自: 大连
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

Linux之父炮轰C++:糟糕程序员垃圾语言

阅读更多

  "Linux内核的创始人Linus Torvalds最近在一封邮件中说明了内核开发需要使用C语言而非C++的理由。在庞大的项目中,人们对不是自己开发的模块并不了解,能快速理解其他模块中函数的 确切含义才能提高开发效率,而C++引入的各种抽象则使代码变得晦涩难读。

  另外Linus还认为C++的内存管理方式很弱智(that idiotic "new" keyword in C++)。邮件最后的总结是:很显然C并不适合所有项目,不过C++?还是算了吧。垃圾回收和并发等等,这些才是真正重要的特性。

  那么他所期待的C++替代会是什么呢?是方兴未艾的Go语言?还是即将迎来2.0的D语言?或是用 Java, .net这些基于虚拟机的语言去代替?"

  此文贴出后,引起了大家的较多关注,是意料之中的事情。毕竟,C、C++、Linux之父,都是大家最最熟悉的东西。但是许多同学把精力放在纯粹语言优劣的争论上,就没有太大意思了。这场争论的主角之一,微软的Dmitry Kakurin有一句话非常正确:"这是一种信仰问题。因此,任何讲道理和争论都会无穷无尽,而且也毫无意义……"

  我想,正确的态度,应该是从高手们的争论中汲取营养,提高和深化自己对相关语言的认识,结合自己的实际环境,想想应该怎么学,怎么用。孟岩和云风、pongba在这方面都有"有营养的"文字,大家可以看看。

  各种语言都是有自己的局限性的,也都有自己最擅长的用武之地。今天,软件项目中越来越倾向于采用多语言开发,所以与其花精力做口舌之争,不如多学学对方的语言。写《程序员修炼之路》的Andy Hunt和David Thomas大师早就教导我们,要在软件开发这个行当立于不败之地,应该"每年学一种新的语言"。

  Linux之父Linus Torvalds为了Linux内核开发而专门打造的版本控制软件Git已经引起了业界的广泛关注。昨天,有一位Dmitry Kakurin老兄在查看了源代码之后,发现使用的是纯C而非C++,表示不可理解,他直言:"别拿可移植性说事儿,这是屁话 (BS,bullshit)。"(此外,他还批评Git蛮力地直接操作文本,既啰嗦又易错,而且很难跟上高层代码逻辑。)

  这个BS引起了Torvalds的强烈反应,他用"*YOU* are full of bullshit."(你才满嘴屁话呢)作为自己反驳的开场白。接着,他先转向了对C++的罕见的火药味十足的炮轰:

  "C++是一种糟糕的(horrible)语言。而且因为有大量不够标准的程序员在使用而使情况更糟,以至于极容易产生彻头彻尾的垃圾(total and utter crap)。老实说,选择C就是为了把C++程序员踢出去。……我有这样的结论,任何喜欢用C++而不是C开发项目的程序员可能都是我希望踢出去的人,免得他们来搞乱我参与的项目。C++会导致非常非常糟糕的设计选择。你们这些C++程序员总是一上来就用语言的那些'漂亮的'库特性比如STL、Boost 和其他彻头彻尾的垃圾,这可能对你们的程序有所'帮助',但是却会导致:

  "--当库无法工作时无穷无尽的折磨(别跟我说什么STL尤其是Boost很稳定而且可移植性很好,那全是屁话,而且一点都不可笑)

  --低效的抽象编程模型,可能在两年之后你会注意到有些抽象效果不怎么样,但是所有代码已经依赖于围绕它设计的'漂亮'对象模型了,如果不重写应用程序,就无法改正。

  也就是说,使用优秀的、高效的、系统级的和可移植的C++的唯一方式,最终还是限于使用C本身具有的所有特性。项目限制只用C,意味着参与的人不会捣乱,也意味着会得到许多真正懂得底层问题,而不会折腾那些白痴'对象模型'垃圾的程序员。

  所以,我很抱歉,但是对于Git这样效率是主要目标的软件,C++的所谓优点只是巨大的错误。而我们将看不到这一点的人排除在外却成了一个巨大的附加优势。

  如果你想要用C++写的版本控制系统,去玩Monotone吧。他们确实使用了'真格的数据库',使用了'漂亮的面向对象库'、使用了'漂亮的C++ 抽象'。可是说老实话,所有这些对某些计算机专业人士而言富于吸引力的设计决定,其最终结果确是一堆可怕、难以维护的垃圾。"

  Torvalds和Dmitry Kakurin争论继续中。

  对Torvalds的回击,Dmitry反唇相讥:"随着只用C编程的恐龙们逐渐灭绝,你很快就会发现只剩下自己一个人在固执己见。用Git贡献者的数量是说明不了问题的。显然C++开发者也能够贡献C代码。但是以为他们喜欢这种方式,那可就错了。

  没有C的时候我用汇编编程。然后在C++诞生之前,我转向了C。现在我使用C++和C#,而且不再走回头路。差劲的程序员用任何语言都写不出好程序。但是为了将差劲的贡献者拒之门外这样一个没谱的理由而惩罚优秀的开发者,这简直是胡闹。"

  只过了10几分钟,Torvalds就回贴了:"和你不同的是,我实实在在地给出了不喜欢C++的原因,而且指出了它可能导致的各种问题的一些例子。而你呢,没有给出一条像样的使用C++的理由。事实上,Git比其他软件配置管理软件都要好,而好的品味(taste)和C正是原因之一。"

  对上面的最后一句话,Torvalds后来又做了如下补充:

  "说得更具体一些:

  --简单和清晰的核心数据结构, 非常精益(lean)且颇具雄心的代码管理着它们,将'简单胜于花哨'这一方法发挥到极致。

  --有意识地不抽象数据结构和算法,因为它们恰恰是Git核心的全部要素(whole point)。

  如果你想用更花哨的语言,C++绝对是最糟糕的选择。如果想要真正的高级特性,那就选择有垃圾回收或者好的系统集成的,而不是既缺乏C的简约(sparseness)又缺乏C的直接而且没有重要概念的高层绑定(high-level bindings to important concepts)的东西。

  一言以蔽之,C++正处在困境当中,它既无法帮助原型化或者简单的GUI编程足够简化从而真正可用,又不是C那样积极地鼓励你使用简单和直接的语言构造的精益系统编程语言。

  (另一位同学插了一句:这还没有提到很难找到两个C++编译器支持同样的特性。)

  这与什么恐龙毫无关系。好的品味永远不会过时。将C与汇编语言相提并论,恰恰说明你对自己所讨论的问题缺乏起码的概念(don't have a friggin idea)。"
分享到:
评论

相关推荐

    Linux之父炮轰C++是糟糕程序员的垃圾语言

    这场争论的主角之一,微软的Dmitry Kakurin有一句话非常正确:“这是一种信仰问题。因此,任何讲道理和争论都会无穷无尽,而且也毫无意义……”

    该是普及G语言的时候了——LabVIEW学习

    Linux之父炮轰C++:糟糕程序员的垃圾语言 C语言已经死了,5个需要忘却它的理由 看看9种编程语言的发明者是怎么说的 顺应时代没有不好,但是时代在变,大家在顺应着的“时代”是真正的时代吗? 模糊!就停下来,停...

    LINUX之父炮轰说

    LINUX之父炮轰C++.。。。。。。。。。。。。。。。。。。。。。。。。。。。。

    星辰急便总裁陈平炮轰电商自建物流.docx

    星辰急便总裁陈平炮轰电商自建物流.docx

    用类封装的战舰小游戏

    本程序模拟了一个炮轰战舰的小游戏,战舰由三块组成,随机生成,炮弹由用户输入。击沉则告之,并显示最终分数,仅作为C++入门新手对类的封装的熟悉之用

    devbox:我用作开发箱的 Docker 映像

    我用以下方法炮轰它: docker run -i -t --volumes-from michiel-data devbox /bin/bash 在我完成了我想做的工作并将我的更改推送到 github 之后,我再次输入“exit”退出。 在我的数据容器(在我的 VPS 上称为...

    二十三种设计模式【PDF版】

    GoF 的《设计模式》是所有面向对象语言(C++ Java C#)的基础,只不过不同的语言将之实现得更方便地使用。 GOF 的设计模式是一座"桥" 就 Java 语言体系来说,GOF 的设计模式是 Java 基础知识和 J2EE 框架知识之间一...

    真正免费,好用的SD、TF卡数据恢复软件,带注册文件,不能用炮轰我。

    真正免费,好用的SD、TF卡数据恢复软件,带注册文件,不能用炮轰我。 为数不多的真正免费可用的SD卡数据恢复软件,百度上的那些什么SD卡数据恢复软件免费版,超级XXXX试用版 都TM得坑爹。

    大炮轰小鸟

    一个flash as2.0编写的小游戏,可以提供给需要的朋友参考

    23设计模式简讲

    因为很多人没有注意到这点,学完Java基础语言就直接去学J2EE,有的甚至鸭子赶架,直接使用起Weblogic等具体J2EE软件,一段时间下来,发现不过如此,挺简单好用,但是你真正理解J2EE了吗?你在具体案例中的应用是否也...

    炮轰“测试左移”,向软件测试领域的“歪理邪说”宣战

    由于一些人或组织有心或者无心的制造一些焦虑,让软件测试的从业者尤其是刚入行的软件测试工程师,对软件测试本身的意义,以及软件测试职业的发展、技术路径、充满了疑虑!在 为什么会有这么一个话题呢?...

    KC网络电话辅助呼叫

    KC网路电话辅助呼叫 软件自动重播,挂断KC网路电话

    authorware7.0 作品--士兵突击

    这是我们课本附赠光盘的 精品赏析 士兵突击的 绝对好资源 如果下了感觉资源不好 你可以直接加我QQ:451092524 来炮轰我

    宇润xv格式视频转换工具

    真正免费版,迅雷视频转换,好用,不能用炮轰我

    pactman:契约管理(模拟,生成和验证)

    关键区别在于所有功能都是在Python中实现的,而不是炮轰或分叉到ruby实现中。 这样可以提供更好的模拟用户体验(直接模拟urllib3),更快,更简单的配置(多个提供程序意味着在不同端口上产生多个ruby进程)。 在...

    卡尺:用于测量图像和PDF尺寸的Node.js库

    构造Calipers的目的是提供一种比炮轰ImageMagick更快,更省资源的方法来确定图像或PDF的尺寸。 在我们必须在API请求有效期内验证图像和PDF的大小。 最简单的方法是将Shell封装到ImageMagick中,以识别文件的类型和...

    scratch编程项目源代码文件案例素材-[僵尸大战1.4].zip

    scratch编程项目源代码文件案例素材-[僵尸大战1.4].zip

    让荣耀和小米高管互掐的ToF技术究竟是什么?

     没过多久,小米集团的副总裁卢伟冰就看不下去了,直接炮轰荣耀近重点推技术是噱头,骗用户瞎花钱。    之所以小米这边反应激烈,我估计还是荣耀说了这么一句:    巧了,近这阵子小米的宣传...

    魔音喊麦.kx效果 回荡,爆音

    我画过游子身上衣 也画过慈母念朝夕 我下过隔子炮轰车 也画过丧殡烧头七 花开花落花弥漫 你看我一生多璀璨 忘情挥舞八卦扇 我再次逆天写震撼....... 忆当年 风雨摇摆 曾经我名震四海 现如今我不再主宰 难以...

    英文文献1

    小贴士到第 3 章刷新上设置你的路径语句,使用的内存,请参阅命令行工具。一旦你炮轰到服务器,你需要定位到数据库将保留的位置。安卓系统的所有 SQLite 数据库

Global site tag (gtag.js) - Google Analytics