4 月初,在 Puget Sound Programming Python(简称 PuPPy)举办的第一届年度慈善活动中,四位传奇的编程语言创始人聚集在一起就编程语言设计的过去和未来展开了热烈的讨论。此次活动旨在为面向所有人的计算机科学教育(Computer Science For All,美国前总统奥巴马当年年初提出的新计划,旨在美国教育体系中普及计算机科学)筹集资金。
与会的小组成员包括以下流行编程语言的创始人:
- Guido van Rossum:Python 的创始人;
- James Gosling:Java 编程语言的创始人兼首席设计师;
- Anders Hejlsberg:Turbo Pascal 的原作者,他也致力于 C# 和 TypeScript 的开发;
- Larry Wall:Perl 的创始人。
此次讨论会由 Carol Willing 主持,目前她是 Jupyter 项目的指导委员会成员和开发人员。她还是首届 Python 指导委员会成员,Python 软件基金会研究员和前任主任。
编程语言设计的关键原则
小组成员提出的第一个问题是:“编程语言设计的原理是什么?”
Guido van Rossum 认为:
编程语言的设计与 J·K·罗琳撰写她的哈利波特系列丛书的方式非常相似。
他解释说,J·K·罗琳是一个天才,她在第一本哈利波特书中提到的一些细节与第六和第七本书中重要的情节相呼应。
在解释这与编程语言设计之间的关系时,他表示:“在编程语言设计中亦是如此,我们需要做到首尾呼应。”在设计编程语言时,首先我们会承诺某些细节,例如我们想要使用的关键字,我们想要遵循的编码风格等等。但是,无论我们做了何种决定,都必须坚持到底,将来我们需要像 J·K·罗琳一样,找到使用这些细节的新方式。
他补充说道:“一方面,在设计编程语言的工作中,最开始你要做出一系列的选择,为你的故事发展埋下伏笔。另一方面,设计编程语言的艺术在于,你需要不断回顾你的故事,并展开奇思妙想,以你始料未及的方式推进故事发展。”
当谈论到 James Gosling 创建 Java 的过程,以及他所遵循的设计原则时,他只是淡淡地说:“Java 的出现并不像个人热爱的项目那样。其实我们只是想试着建立一个原型。”当时,James Gosling 和他的团队开展了一个涉及嵌入式系统领域的项目。为此,他们与许多为嵌入式系统构建软件的开发人员进行了交谈,并了解了他们的工作流程。
该项目大约有十几个人,Gosling 负责从编程语言的角度来尽量简化项目。他补充说:“最初我们只想做比 C 更好的东西,但是后来就失去了控制,最终项目的其余部分只是提供了素材。”唯一从该项目中幸存了下来的就是“Java”。基本上该编程语言就是为了解决身居数据中心之外的人的问题,这些人常常为网络、安全性和可靠性等问题困扰。
Larry Wall 觉得自己更像“语言学家”,而不是计算机科学家。他想创造一种更接近自然语言的编程语言。他举了一个例子:“就好像我们不必让每个人都走进大学校园才能决定他们各自的去向,我们可以观察人们想去哪里,然后设置通向这些地方的捷径。”Perl 创建背后的一项基本原则是通过 API 提供一切功能。这种编程语言的目标不仅是建立一种优秀的文本处理语言,而且也想成为一种胶水语言。
Wall 进一步说,虽然在 90 年代 Perl 非常稳定,但也确实存在一些问题。因此,2000 年的时候,Perl 团队决定打破一切,并提出了一套全新的设计原则。而且,他们还根据这些原则,重新设计出了 Perl 6。其中一些原则做出了正确的选择——保守地使用括号,否则算上 Unicode 的括号也不够用;无需蹩脚地重新发明面向对象等等。
他补充说,
“大量的重新设计就像是说,我们该用哪根柱子支撑一切?新的设计是面向对象的吗?是在词法作用域内重新设计,还是在更大的范围内?每片信息的正确的支柱是什么?如果我们根本没有支柱的话,该如何创建?”
Anders Hejlsberg 表示,他遵循了他所接触过的所有编程语言的共同原则,即“做某件事情的方法只有一种。”他认为,如果开发人员有四种不同的方法,那么最终很有可能会选择错误的道路,而且要过很久才能在开发中意识到这个错误。根据 Hejlsberg 的说法,这就是为什么开发人员总是会创建一种名为“简单的复杂”的东西,也就是说拿到一些复杂的东西后,通过简单的打包来掩盖复杂性。
与 Guido van Rossum 的观点相似,他进一步补充说,在设计一种编程语言的时候,无论你做出怎样的决定,都必须坚持到底。在设计编程语言的时候,你需要谨慎地决定“不”将哪些东西引入到这种编程语言中。通常,人们会向你提出他们的建议,但你无法真正改变编程语言的本质。虽然你无法真正改变语言的基本性质,但是你可以进行扩展。基本上你有两个选择:要么坚持语言的本质,要么开发一个新的编程语言。
编程语言的类型系统
在谈论到 Python 决定类型的方法时,Guido van Rossum 分享了 Python 首次推出时的一个故事。起初,int 不是一个类,实际上它是一个转换函数。后来,Guido 意识到这是一个错误。“我们有很多这样的功能,我们意识到我们犯了一个错误,我们向用户提供了与内置对象类型不同的类。”
于是,Python 团队决定重新构建 Python 的整个类型,并进行了大量的清理。因此,他们将函数 int 更改为类 int 的指定符。现在,调用这个类意味着构造该类的实例。
James Gosling 表示一直以来他都很注重性能,而提高性能的一个因素是类型系统。在构建优化编译器和提前检查正确性等方面,类型系统非常实用。拥有类型系统也有助于为小型设备构建系统的情况。他说:“为了能在有限的空间内工作,你必须了解设备提供的每一种可能性,而且你知道得越早,就越有可能出色地完成工作。”
Anders Hejlsberg 将类型系统视为一种工具。开发人员喜欢他们的 IDE,他们习惯于使用语句的自动补齐、重构和代码导航等。这些功能是通过代码的语义知识而实现的,而这种语义知识正是由类型系统的编译器提供的。Hejlsberg 认为,添加类型可以大大提高开发人员的生产力,虽然这与我们的直觉相反。
他补充说:“我们以为动态语言更容易掌握,因为你摆脱了类型的束缚。然而,事实证明,如果你以非侵入的方式添加类型,同时努力做好类型推断等,那么就可以提高效率。”
谈到 Perl 中的类型系统时,Wall 表示 Perl 5 和 Perl 6 有不同类型的系统。在 Perl 5 中,所有类型都会被视为字符串,即便是数字或浮点类型。该团队希望在重新设计 Perl 6 的时候依然保留这个功能,然而他们意识到:“如果新用户对可互换性感到困惑,那还好;但如果连计算机都感到困惑,那就不妙了。”
于是,在 Perl 6 中,Wall 和他的团队希望将其打造成更好的面向对象以及更好的函数式编程语言。为了实现这一目标,他们需要一个非常合理的类型系统,并在底层建立一个非常合理的元对象模型。此外,你还需要非常重视“一切都是对象,一切都是闭环”的口号。
影响编程语言维护性的因素有哪些?
Guido van Rossum 认为,如果想加强编程语言的维护性,那么就需要在灵活性和规范性之间取得恰当的平衡,这一点非常重要。虽然对于小型程序来说,动态类型更好用,但大型程序则需要采用严格的方法。而且,最好能够通过编程语言本身实现规则,不要给用户留下太多自由发挥的空间。出于这个原因,Guido 打算在 Python 中添加类似 TypeScript 的技术。他补充说:
“实际上,TypeScript 非常实用,因此我们也想在 Python 中添加类似的概念。当然我们的添加方式会略有不同,因为我们的语言环境不同。”
除了类型系统以外,事实证明重构引擎也非常有用。有了重构引擎后,就可以一次执行数百万行代码的大规模重构了。通常,人们不会重命名方法,因为你很难认真看完一段代码,然后正确地给每一个变量重命名。如果你有一个重构引擎,那么只需点下几个按钮,输入新名称,然后 30 秒内就可以完成重构。
Anders Hejlsberg 表示,TypeScript 项目源自一些庞大的 JavaScript 代码库。随着这些代码库变得越来越大,维护工作变得异常艰难。后来基本上这些代码库变成了“只写的代码”。他补充说,因此我们需要理解代码的语义,而这个过程也降低了重构工作的难度。他表示:“这种语义的理解需要一个类型系统,而且在你开始添加类型系统时,你还可以添加代码的文档。”Wall 也支持“良好的词法作用域有助于重构”的观点。
编程语言设计的未来
在谈论到编程语言设计的未来时,James Gosling 分享了编程中一个未充分探索的领域——编写使用 GPU 的代码。他强调说,目前我们的编程语言都无法直接利用 GPU,我们应该加大这个领域的发展。
Anders Hejlsberg 表示,编程语言不会像硬件或所有其他技术那样快速地变化。就发展速度而论,编程语言更像是数学和人脑。他说:“我们仍然在使用 50 年前发明的语言进行编程,所有的函数式编程原理都是 50 多年前的研究成果。”
但是,他也相信,如今的编程语言趋于多范式,不会严格区分面向对象编程或函数式编程等类别。
“语言正在走向多范式。我觉得我们不应该再说我只喜欢面向对象的编程、命令式编程或函数式编程语言。”
如今,更重要的是我们需要了解最新的研究、新思维和新范式,并优雅地将这些新思想融入到我们的编程风格中。
会谈视频
完整的近三个小时的会谈视频如下:
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/linux/56479.html