这是几年前的一篇文章,分享给大家

几个月之前,Slashdot转载了Robert Harper教授的一篇博客,说卡内基梅隆大学计算机系把”面向对象编程“从大一新生的必修课中删掉了,其原因是:

Object-oriented programming … is both anti-modular and anti-parallel by its very nature.(从其本质来讲,面向对象编程既反模块化,又反并行。)

这两个原因(anti-modular和anti-parallel)都是很重的指责了;尤其是anti-modular,因为OO的基本思想通常被理解成“封装”,从而实现模块化。

我是在1995年第一次听说“面向对象”(Object Oriented)这个说法。当时在学习正在成长过程中的C++,用的是Borland C++ 1.0。从那时开始的很多年里,”类“(class)、“对象”(object)和“方法”(methods),以及在这些概念之上构建的”继承 “(inheritance)和”多态“(polymorphism)都是我理解中OO最核心的思想。我猜大多数程序员在这方面的认识都和我差不多。

但是“封装”真的是OO的本质嘛?直到最近为了给iPhone写个玩具程序而学习Objective-C(一种非常古老和原始的面向对象编程语言)的时候,才注意到早在1998年,OO之父Alan Kay就曾经在一篇邮件中说,他很后悔发明了“object”这个词,从而误导大家,把注意力都集中到“封装”,而忽视了OO的本质——messaging(消息传递)。Alan Kay的原话是:

The big idea is “messaging”…. The key in making great and growable systems is much more to design how its modules communicate rather than what their internal properties and behaviors should be.

Objective-C的设计是非常强调“消息传递”(messaging)的——对一个object的method的调用,被称为“给这个 object发了一个消息”。为了突出调用method时指定的参数(parameters)实际上是消息中的一些内容,Objective-C不惜把 method的定义方式都做了相对于C的很大的修改,从而把参数嵌入在method的名字里。比如在一个叫做myWebView对象中搜索一段文字,要求 不区分大小写,从前往后搜索,用Objective-C来描述是:

[myWebView searchFor:myString direction:YES caseSensitive:NO wrap:YES]

而用C++或者Java来描述,则是myWebView.searchFor(myString, YES, NO, YES)

乍看上去,C++或者Java的方式更简短,但是Objective-C的方式更强调“发消息”。实际上,上面Objective-C语句会被翻译成如下C函数调用:

objc_msgSend(myWebView, searchFor:direction:caseSensitive:wrap:, myString, YES, NO, YES

从强调messaging的角度看,Objective-C确实比C++和Java更符合Alan Kay对OO思想的描述。

OO中的messaging思想不仅体现在Objective-C语言以及在其上构建的NextSTEP/Cocoa GUI编程套件上。在Cocoa因为Mac OS X和iPhone流行起来之前,很多人都接触过Qt(一种基于C++语言的GUI开发套件)。Qt对messaing的支持比Objective- C/Cocoa更彻底——每个object可以发出若干signal,每个signal可以触发这个object自己的或者其他objects的若干个 slot。

有意思的是,为了支持messaging,Qt对C++语言做了扩展,而Objective-C对C语言做了扩展。这两套扩展都利用了起源于C 语言的“宏”机制(macro)。类似的做法也可以用于Java,前提是我们在调用Java编译器之前,先调用一下cpp宏展开程序来预处理一下我们的 Java程序。这事儿可以留待Java爱好者们来搞?

不管是Objective-C还是Qt,都会“尽力”去检查一个object是否支持一个method(或者叫message),但是并不禁止 程序员向一个object发送一个它不认识的message(或者调用一个object没有的method)。说“尽力”检查,是因为两者都不能保证检查 的完备性。这是因为Objective-C和Qt都支持多态;具体的说,接受message的object可能是表示为一个指针(指向object),所 以直到运行时候,当一个message抵达某个object的时候,系统才能(通过查这个object对应的message list)知道这个object是否认识这个message。

这种灵活性在Google新推出的Go语言中也同样实现了,而且做的很极致——Go语言中没有class的概念;换句话说,不需要是class 类型的object才能有对应的方法(methods)——Go允许给几乎任何类型附上methods。而且程序中可以很方便的检测一个object是否 支持(一组)methods

说到这里,我觉得差不多可以反过来理解Robert Harper教授对OO的评价了——其实Robert不是在藐视OO,而是在指责很多imperative OO languages(我理解包括Java和未经Qt扩展的C++;详见后述),认为这些语言没有完成实现OO中object messaging的核心思想,从而不算实现了“模块化“(modulization)的思想。

上述都是关于程序的模块化。实际上,模块化的另一个主要方面是对“数据”(data)的模块化。从图灵机和lambda-calculus开 始,计算机科学家们就注意到程序和数据是统一的;比如在冯诺依曼的“二进制存储电子计算机”模型里,程序和数据都是bit stream。即时我们在讨论高级编程语言的时候,程序和数据也不应该被分开。因为现代数据操作和模块化的基础是并行程序(parallelism),而 有效实现并行的基础是程序的first-class表达,也就是把程序作为一种基本数据类型。

杂谈现代高级编程语言相关推荐

  1. 机器指令到汇编再到高级编程语言!

    Part 1. 机器指令 上一次 我们已经了解了 二进制和 CPU 的基本原理,知道了程序运行时,CPU 每秒数以亿次.十亿次.百亿次地震荡着时钟,同步执行着微小的 「电子操作」,例如:从内存读取一个 ...

  2. 已知x=python是一种非常好的编程语言-为什么用Python,高级的Python是一种高级编程语言...

    Python特性 如果有人问我Python最大的特点是什么,我会毫不犹豫地告诉他:它简单易学,功能强大.作为一个纯自由软件,Python有许多优点: 很简单.基于"优雅".&quo ...

  3. dec++如何查看机器指令_机器指令到汇编再到高级编程语言!

    Part 1. 机器指令 上一次 我们已经了解了 二进制和 CPU 的基本原理,知道了程序运行时,CPU 每秒数以亿次.十亿次.百亿次地震荡着时钟,同步执行着微小的 「电子操作」,例如:从内存读取一个 ...

  4. Win知识 - 程序是怎样跑起来的——系统调用和高级编程语言的移植性

    操作系统的硬件控制功能,通常是通过一些小的函数集合体的形式来提供的.这些函数及调用函数的行为统称为系统调用(system call),也就是应用对操作系统(system)的功能进行调用(call)的意 ...

  5. 基于c的语言开发,基于CC++等高级编程语言开发电子系统的设计自动化系统.doc

    基于CC等高级编程语言开发电子系统的设计自动化系统 基于CC++等高级编程语言开发电子系统的设计自动化系统 摘 要:当前电子系统设计自动化技术已广泛地应用于各个领域,随着科技的发展,对电子系统设计自动 ...

  6. 【plang 1.4.6】Plang高级编程语言(发布)

    系统简介 Plang是一门体现JVM(Java Virtual Machine)规范,使用C++自主开发的高级编程语言,主要用于Windows10平台下C++游戏系统脚本开发(预计支持mac os/l ...

  7. 科普了解高级编程语言的发展历程

    原文标题:高级语言是怎么来的 高级编程语言的发展历程(一) 创始纪 2009-5-13 原文链接 终于放暑假了,有心情来八卦了.我主要想八卦一下高级语言的设计思想和各种范式的来龙去脉,也就是回答这个问 ...

  8. 高级编程语言的发展历程(机器语言、汇编语言、高级语言)

    目录 高级编程语言的发展历程(一)创始纪 高级编程语言的发展历程(二)虚拟机的前世今生 高级编程语言的发展历程(三)FORTRAN 语言是怎么来的 高级编程语言的发展历程(四)LISP 和 AI 的青 ...

  9. 「MoreThanJava」机器指令到汇编再到高级编程语言

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

最新文章

  1. 重大里程碑!VOLO屠榜CV任务,无需额外数据,首次在ImageNet 上达到87.1%
  2. ajax bootstrap 进度条,Bootstrap进度条与AJAX后端数据传递结合使用实例详解
  3. linux常用指令_Linux系统常用指令总结
  4. select,poll,epoll区别面试常问
  5. Spring Security构建Rest服务-0702-短信验证码登录
  6. 防止mysql拷贝_转载:mysql复制优化
  7. Android之通过用户名和密码连接指定wifi热点(兼容Android9.0和Android10.0和addNetwork(wifiNewConfiguration)返回-1问题)
  8. Java中的SynchronousQueue示例–生产者使用者解决方案
  9. mysql run sql files_HeidiSQL_5.1_Sourcecode
  10. Android 系统(43)----Andropid 基础知识
  11. 初探Openstack Neutron DVR
  12. UVA11764 Jumping Mario【Ad Hoc】
  13. python水仙花数判断程序
  14. 2022年MathorCup 赛题浅评
  15. [转]Hooked on DTrace
  16. 留言板php添加图片_php实现留言板功能
  17. 数据库原理必背简答题【计算机考研复试】
  18. 四川全国计算机一级考试查询系统,2013四川计算机一级成绩查询入口
  19. 街头篮球服务器未响应,肝的飞起 《街头篮球》魔王试炼FAQ
  20. 26个字母大写及小写分别对应的ASCII码值

热门文章

  1. OpenFOAM编程基础(1) - Hello World
  2. 上线7天获得1000万保险用户 支付宝相互保究竟释放了怎样的信号?
  3. 论文解读 | Transformer 原理深入浅出
  4. CLINT和PLIC,risc-v中断
  5. VC6.0经典字体 Fixedsys字体
  6. 打印机技术分析:IC芯片墨盒解密(多图)
  7. 矩阵加法python实现
  8. 黑客基地攻防特训班教程
  9. FloatingActionButton悬浮菜单按钮的实现
  10. 微软128核服务器,王思聪的百万元电脑:64核心128线程/跑分世界第四