C++之父Bjarne Stroustrup:程序员在数学上付出的努力,永远也不会白费

0aef40722b7a5b0bf2d2c6bf2410768f.gif

7e424356be142dd562f5af3efbb26575.png

导读:1979年诞生的C++已迈入“不惑之年”,如今却依旧在主流编程语言中占据重要一席。但今天,我们不再赘言C++的成功史,而将目光转向C++背后的英雄——C++之父Bjarne Stroustrup。在本篇文章中,让我们跟着软件开发商Evrone的采访,共享Bjarne Stroustrup四十余年程序人生中所蕴藏的大量经验财富。

2a10d711313e0c9825d1f1a516030b05.png

作者 | Evrone,已获作者翻译授权      

译者 | 弯月

出品 | 《新程序员》编辑部

作为最初只是出于改进C语言、增加部分基于面向对象编程功能的C++,它的成功令C++之父Bjarne Stroustrup自身都感到意外:“C++的成功令人惊讶。”

不过,也是因为C++一直广受开发者喜爱,Bjarne Stroustrup多年来始终坚持在开发一线——目前71岁的他仍在积极参与C++开发工作。经常有受益于C++的开发者说,C++改变了他们,但殊不知,C++改变的,还有Bjarne Stroustrup自己。

a78ec4a0236eb5d543d51d6df498bd79.png

(图片来自 Bjarne Stroustrup 个人主页)

1C++ 对 C++ 之父的影响

Evrone:您创建了一门高效且快速的编程语言,这无疑改变了我们的世界。请问对您个人而言,在创建这门语言的工作中是否也发生了变化?

Bjarne:我从未想过这个问题,不过我认为这个问题可以从两个角度进行回答:哪些方面长期保持不变,又有哪些方面发生了巨大变化。

从很久以前开始,我就对历史、哲学等许多领域都抱有广泛兴趣,多年来也一直保持不变,我认为这对C++的发展具有重要意义。因此,相较于深入研究学术,我更想要建立更多东西,这也给我对工程领域的看法带来了一定“偏见”。我看重性能、低成本和可靠性,再加上我很重视反馈、不断进步以及对现实世界问题的理解,最终造就了C++。

多年来,在我工作中持续稳步发展的一个方面就是教育。当我试图解释自己的想法时,我逐渐意识到:不能只是做出来,你必须教人们如何使用它。这也是C++一直存在的问题。通常,我的个人看法会被其他人的声音所淹没,这些人往往有着更简单的愿景并提出更大的主张。在20世纪80年代和90年代,我们经常会听到“我们没办法迅速培养教师”之类的抱怨,所以C++的教学常常采用一种在我看来很糟糕的方式,也难怪有些人会对C++抱有非常负面的看法。

如果我能早点知道自己一生中的大部分时间都在说写英语,那么我一定会在英语上更加努力。这些年来,我需要面对并解决许多问题,这些问题种类繁多且范围广泛,在这过程中我对它们也有了很多见解。许多困难的问题都与组织、管理和教育有关。与技术教育相比,广泛的阅读令我更加受益匪浅。我明白了良好的语言设计需要高度谦逊,因为我们不了解的东西太多:这个世界在不断变化,我们的问题在不断变化,而我们自身也在变化。

2洞悉行业当前现象及趋势见解

Evrone:强大的C++元编程系统有时会被滥用,开发人员会想方设法将任务从运行时转移到编译时。在您看来,有没有什么可行的解决方法?

Bjarne:每一种新颖且强大的功能或技术都会被过度使用和错误使用,对此我想不到有什么好办法。不过这也会带来一定好处,因为过度使用会让我们认识到弱点,并设法解决。

举个例子,C++模板元编程非常有用,因此许多人愿意忽略它的不足及其负面消息去使用它。后来,我们从中总结了大量经验,利用编译时求值的函数(constexpr和consteval)和概念来弥补相关不足,大大简化了手动编写的大部分代码。

Evrone:业界流传着一个“笑话”,即任何架构问题都可以通过引入新的抽象层来解决,结果却导致抽象层太多。我们看到很多C++代码都有大量的抽象类,那么作为C++创始人,您认为如何才能让每个抽象类都发挥积极作用?

Bjarne:这就是David Wheeler的“计算第一定律”,他是我的论文导师,也是一个了不起的人,我从他身上学到了很多。

你说的这个“笑话”反映了现实,人们确实喜欢将真正的逻辑隐藏在多层接口之后,还会使用大量的间接方式,但这可能会导致代码量和运行时间增加一到两个数量级。因此,现代C++的大多数功能就是为了让人们编写的接口能被编译器优化成更简单的机器代码,尽量减少使用无谓的间接方式。

Evrone:随着DeepMind的AlphaCode神经网络的问世,越来越多媒体声称这种神经网络很快就会取代程序员。您认为这种说法有依据吗?

Bjarne:我不太确定。我也很怀疑人工智能是否真的能够取代我最关心的编程类程序员,但我认为可靠性和最佳性能不太容易被标准化和平均化。AI不是我的强项,但TensorFlow和类似的库都有C++的身影,这也就意味着——不论好坏,起码我已经尽了自己的一份力。

Evrone:在过去十年中,我们看到许多语法糖(对语言的编译结果和功能没有实际影响、却能更方便程序员使用该语言的语法)被添加到主流语言中。似乎通过“臃肿的语法”为开发人员提供更好的工具已成为一种趋势,您对此如何看待?

Bjarne:只要能减轻程序员的负担,即便是“臃肿的语法”也无伤大雅,我更愿称之为“让简单的任务变得更简单”。我认为,关键思想是让程序员能直接在代码中表达基本思想。例如,用C语言风格的循环来表达容器上的简单循环没有任何优点或好处,最好使用range-for或算法。在大多数情况下,这些方法都能直接表达意图,只有在特殊情况下才需要考虑复杂的循环变量,例如在访问容器的元素时,不是挨个访问,而是隔一个访问一个。想法越直接,编写、阅读和维护代码就越容易,并且通常优化也越简单。

因此,我不认为“应该只有一种表达方式”是一种理想的做法,这种思想会导致有些情况很难表达,而有些情况确实需要大费周折才能表达出来。此外,经过长年累月的优化,语言本身也会发生变化。从这些角度来看,编程语言与自然语言并没有什么不同。

3开发人员该如何突破困境?

Evrone:如今人们普遍认为,使用现代框架比应用数学知识更重要,您能在这方面给程序员一些建议吗?

Bjarne:程序员在数学上付出的努力永远也不会白费。数学是训练我们大脑的最佳方法之一,尤其是与计算相结合时,我们很快就会意识到自己的错误;数学也教会了我们一丝不苟,不要轻信过于简单或错误的想法。

在很多领域中,数学知识都是必不可少的,例如科学计算、某些图形形式和许多金融软件。但对大多数人来说,数学的关键领域是概率和统计:你的代码速度够快吗?能扩展吗?某些事件的发生概率是多大?影响是什么?

当然,也有许多应用程序不需要数学,但在构建基础设施或大规模部署应用程序时,容量和能耗的成本不容忽视,此时数学知识的不足就可能会带来危害。

Evrone:有时作为开发人员,面对手头的编程任务,我们总是找不到合适的解决方案。您有没有遇到过类似情况,可否分享一些处理这类困境的建议?

Bjarne:当然遇到过。在面对新奇或重大难题时,每个人都需要付出巨大的努力,可能几小时、几天甚至更长时间,我们可能还会陷入困境,感到无助和沮丧。

这个时候,我们需要从逻辑层面来看问题。仔细想想你的目标是什么,或许是因为你努力的方向不正确,或许是因为你提出的要求不合理。也可以偶尔休息一下,想想别的事情,我一般会去跑步。放松下来以后,脑海中就会浮现一些有用的想法。

Evrone:业务环境时常要求我们在实现新功能时严格遵守最后期限。在您看来,开发人员要如何在代码质量和开发速度之间保持平衡?

Bjarne:这很大程度上依赖于管理结构和技术文化。我的个人意见(主要基于贝尔实验室的工作经历)是,如果你的组织内人才济济,就不必要求所有人都为下一个截止日期而努力。你需要一些关键人物为未来做策划、开展实验、构建下一个重要系统的第一个版本及后续版本。我认为,一个好的组织需要构建稳定的产品线,其中绝大部分都应在已部署并进入维护阶段的产品上进行革命性变更。不过显然,这种做法与常见的削减成本和发布颠覆性系统的思想背道而驰。

Evrone:许多人将您视为自己的导师,那么在您看来,一位优秀的导师应具备哪些品质?

Bjarne:愿意倾听并认真理解问题。在提供建议时要保持一定的谦虚,因为一般情况下,我们的理解都是不完整的。除此之外,优秀的导师必须给出具体建议,而不是一通模棱两可的废话。如果有人认真向你请教问题,你就应该给出严肃的答案助其进步。但老实说,提供建议也是一件很难的事。

不过教学相长,这也是我们进步的主要动力,一位优秀的导师会从学生身上学到很多东西。

4预告C++的未来发展

Evrone:您能透漏一下在C++未来的版本中会出现哪些变化吗?

Bjarne:首先,社区必须适应C++20全新、强大并简化的特性,它在C++11的基础之上推出了很多提升。C++ 20有很多语言特性,还有标准库组件之类的,但在这里,我只介绍其中两个语言特性。

  • 模块:我们可以认为,import Mod可以访问由module Mod导出(exported)的接口。这种方式更加整洁,与之相比,#include则会泄漏实现细节和宏。此外,模块的编译速度也得到了大幅提升。例如,简单编译一段import std代码的速度比#import<iostream>快十倍(注意:std包含所有标准库,而<iostream>不到其10%)。std模块目前仍处于试验阶段,但经投票已被纳入C++23。

  • 概念:在C++20之前,所有模板都是不受约束的,也就是说,它们没有定义接口以供开发人员和工具查看模板的参数要求,但C++20中提出了“概念(Concepts)”弥补这一缺点。我们一直希望实现这种受约束的模板参数,只不过以前我不知道如何在不限制灵活性或增加运行时开销的情况下实现这个想法。现在我们可以检查模板的使用情况,在出错时得到改进后的错误消息,也可以重载函数模板,甚至提升某些方面的性能。

至于之后的版本,受疫情影响,很多功能的开发都被推迟了。我们希望能够在C++23中推出一些重要的功能,但很可惜,我最喜欢的一些功能未能如愿进入C++23。在这里,我只透露三点。

  • 静态反射:我们需要一种机制来根据程序中的类型在编译时生成代码,这不仅可以为我们提供运行时反射的灵活性,而且无需时间或空间成本。例如,我们可以针对一组固定类型,很容易地生成优化过的JSON阅读器。在这方面,我们已经付出了巨大努力。

  • 模式匹配:在许多函数式编程语言中,根据表达式与一组类型或备选值的匹配程度来选择操作,是表达备选操作最方便的方法之一。我们可以在C++中实现相同的功能,且在此过程中无需使用switch语句。我们有一个非常完整的设计和一个实验性的实现,所以我非常期待C++26。

  • 并发模型:多年来,我们一直在研究一个通用的并发模型,可惜我们发现的总是明显不太适合的用例,因此我们不得不再三推迟。但我希望C++26能有所突破。

最后,有一点需要记住:单凭一个功能并不能让编程变得方便、安全且高效。我们需要在类型系统中创建大量特性,同时,我们又不能破坏现有的数十亿行C++代码,因为兼容性和稳定性是非常重要的特性。

原文地址:https://evrone.com/bjarne-stroustrup-interview

本文为 CSDN 翻译,转载请注明来源出处

RECOMMEND

推荐阅读

f7567862bff982357699974c6365cfd2.png

01

《C++程序设计语言(原书第4版)》

33525a354792a700a6d442df56b6d2b2.png

作者:本贾尼·斯特劳斯特鲁普

C++之父作品

豆瓣评分9.2!畅销全球40余年!

数百万程序员推崇之作!世界名校核心教材!

内容全面,探究原理,698条编程建议、1000余代码示例

推荐理由

从C++语言设计者的角度讲解了专业C++程序员需要的每个语言特性和标准库组件,并解析了它们的设计初衷、原理和制约因素,是数百万C++程序员学完后推崇备至的C++语言学习宝典。

b5a2aa2c72127c60fa46bf059c764e35.png

02

《C++程序设计:原理与实践(原书第2版)》

e31fef4000bdb4bc22c1f6b1a0d33353.png

作者:本贾尼·斯特劳斯特鲁普

C++之父作品

豆瓣评分8.9!畅销全球20余国!

专注程序设计而非C++语言,教你编写“有用的程序”

1182道习题助你实现从“工匠”到“艺术家”的升华

推荐理由

专注于C++程序设计技术、实践和技巧,而非C++语言本身,是一本能让你学到基本的实用编程技术(包括支持这种技术的编程思想和语言工具)的最简单书籍,能帮助你理解并编写复杂的程序。它会教你编写“有用的程序”,而非“玩具程序”,帮助你实现从“工匠”(码农)到“艺术家”的升华。

95d374d9ed254a80791b6f57e76f5f4e.png

03

《C++语言导学(原书第2版)》

f1a99f99d9c903f254e41ff372ab2c38.png

作者:本贾尼·斯特劳斯特鲁普

C++之父作品

豆瓣评分8.9!适合有一定编程基础的程序员阅读学习

322条编程建议,3小时带你认识完整的C++

推荐理由

本书是为有其他编程语言经验(如Java)快速了解C++量身定做的,它覆盖了C++大多数语言特性和标准库组件,但只是概览,能带你在3个小时内认识完整的C++及其背后的设计思想。写作手法、内容结构、示例选取都推陈出新,不枯燥,不教条;文字虽少,内容却丰富,直指关键。

9ca38da07c2dd9e422e26d2744c8c967.png

04

《C++编程思想(两卷合订本)》  

b1fb3f7f561f322682a1add662f617f8.png

作者:(美)Bruce Eckel, Chuck Allison

荣获《软件开发》杂志评选的Jolt生产力大奖

推荐理由

本书是《C++编程思想》两卷的汇总。第1卷是在第1版的基础上进行了更加深入分析和修改后的第2版,其内容、讲授方法、选用实例以及配套的练习别具特色,可以供不同程度的读者选择阅读。第2卷介绍了C++实用的编程技术和最佳的实践方法,深入探究了异常处理方法和异常安全设计;介绍C++的字符串、输入输出流的现代用法;解释多重继承问题的难点,描述了典型的设计模式及其实现,特别介绍了多线程处理编程技术。

eacc3199f2a5820843b308383748a409.png

05

《Big C++中文版(原书第3版)》  

08669d1c231bae393e6406b1239af11a.png

作者:(美)凯·霍斯特曼

《Java核心技术》作者作品

先学习基础理论,之后通过实例逐步掌握面向对象编程思想

推荐理由

本书由经典畅销书籍《Java核心技术》的作者Cay Horstmann撰写,非常适合C++初学者和爱好者阅读,不仅能够帮助新手快速入门,掌握基础知识,而且有益于培养读者解决实际问题的思维和能力。

书中采用传统的讲授方法,首先强调控制结构、过程分解和数组算法,在较为靠前的章节中就适时地引入了对象的概念。从第9章开始,读者将动手设计和实现自定义的类。最后介绍数据结构和算法,涉及高级C++特性。

1b508c7680150be81635391a0f89cb98.png

06

《C++20编程技巧:98个问题解决方案示例(原书第2版)》  

a2038349116327527a09c9c3b121fc39.png

作者:J. 伯顿 布朗宁(J. Burton Browning)

布鲁斯 萨瑟兰(Bruce Sutherland)

探索C++20新特性,涵盖C++核心语言标准,

含98个实际问题解决方案示例

推荐理由

本书带你探索 C++20 的主要新特性,包括模块、概念、飞船运算符和智能指针。通过本书,你将学习数字、字符串、日期、时间、类、异常、流、流程和指针等。 此外,你还将看到各种代码示例、C++ 算法模板、并行处理、多线程和数值处理、 3D 图形编程代码等。同时,本书还提供了大量的STL模板,如函数对象模板、适配器模板、分配器模板和扩展模板。

c550c1866f57b3c31bf7cc2fea324a2c.png

07

《计算机科学的逻辑基础》

67d9c0f806262e1338c2ebcf5e4e8f9c.png

作者:雷克斯·佩奇、鲁本·冈博亚

推荐理由

完美实现逻辑与计算机的知识贯通,培养计算机学生数理逻辑思维。 

本书以实际问题的求解为导向,对计算机科学的逻辑基础知识进行了介绍、讨论和归纳,完美地实现了逻辑与计算机之间的知识贯通。本书主要内容包括逻辑与等式、计算机算术、算法、计算实践四个部分,采用三种形式化表示法,即传统的逻辑代数公式表示法、数字电路图表示法以及ACL2表示法实现逻辑推理。

83df03dc080da6f69517f06ffe040ad1.png

08

《离散数学:面向计算机科学专业》

9bf4a61f20da81394b3a95ee30f7fd79.png

作者:[美]克利福德·斯坦、罗伯特·L.戴斯得尔、肯尼斯·博加特

推荐理由

本书由计算机和数学领域的三位教授联合撰写,旨在满足计算机专业对离散数学课程的需求。针对这门课程的困境——初入学的本科生不理解为何要学习高深的数学,以及授课教师难以向毫无编程经验的学生讲授繁杂的算法程序——本书明确了“为何学”和“有何用”,打破了传统的课程顺序和教学方法,不仅清晰呈现了计算机专业学生必需的数学知识,而且通过实践和应用激发学生对后续课程的学习兴趣。

677f55032e46943b05cf686ebf69bc55.png

09

《优美的数学思维:问题求解与证明》

5ee392d3b38a92393a652bce2c91de11.png

作者:约翰· P.丹吉洛、道格拉斯· B.韦斯特

推荐理由

本书以大量生动有趣的问题求解实例为背景,使用通俗易懂的语言,深入浅出地介绍优美的数学思维和严谨的证明方法,所涉及的数学内容不仅包含函数与集合、数学归纳法理论、组合计算与组合证明、整数理论、数理逻辑、图论等离散数学,而且包含微积分与实数理论等连续数学,覆盖了多个不同的数学领域。本书内容在逻辑上层层展开、环环相扣,形成一套相对完备的知识体系。本书的内容可以有效地激发读者的学习兴趣,唤醒读者的数学潜能和数学思维

dc61e9cd6328dce9d004f6b1cb9aa294.png

4bc91b81b7d992784bb68c9ad3c4d024.gif

ab8442074d42ae04daec919c34519b3d.png

特别预告

享誉全球的 Java 经典著作《Java核心技术》基于Java17 全新升级!6月11日(本周六),作者Cay S. Horstmann先生将带来他的最新研究成果分享:从Java的新特性看Java的未来扫描下图二维码报名观看

bee20a733e0dfaaae46b5526177e7b43.png

0996267ac6bf11211f4e40a1f840f15e.png

更多精彩回顾

资讯 | Java 经典著作《Java核心技术》基于Java 17全面升级!

干货 |Java17 新特性,你需要掌握它

干货 |再见了Java8,Java17:我要取代你

资讯 | Java核心技术大会2022 · 重磅发布

书单 |今天,Java27岁了!

书讯 |6月书讯(上)| 浅夏读新书,与世间万物一起成长

书讯 |6月书讯(下)| 人机物三元融合,开启新世界大门

abb4ae42451abc7344286cc0758a12f3.gif

4ad4214f7e8d4ce265ee7625502a7c21.gif

点击阅读全文购买

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值