Edsger W. Dijkstra -- 巨人的肩膀

news/2025/1/13 5:51:13/

  本文为原创,可能有一些不太严肃的胡说,请勿转载

Dijkstra:宗师、巨星,计算机学科的奠基人之一

  
  牛顿有句名言:“如果我看得比别人更远些,那是因为我站在巨人们的肩膀上1

  在计算机科学界,荷兰人Edsger W. Dijkstra(EWD,狄克斯特拉)是公认的的巨人,抗起计算机学科发展的奠基人之一。从22岁到70岁近40年,他在计算机软件和理论方面做了很多开创性工作,伴随着计算机学科从懵懂到成熟的年代。他创造了大量常用的、写入权威教科书的基本计算机概念和术语,制订了很多编程技术的指导性原则,例如堆栈(stack)、显示(display)、信号量(semaphore)、死锁(deadlock)、互斥(mutual exclusion)、结构化编程(structured programming)等等。
  Dijkstra获得无数荣誉,其中最有名的是ACM图灵奖。1972年第七届图灵奖,当Dijkstra得知自己获奖时,十分惊讶,因为这个美国ACM协会设置的奖很少颁给非美国人。而且,直到24年后的1996年,才有第2个非英美人获奖。
  在1966-2000年间,共有41人获ACM图灵奖,其中:“美国出生+美国求学+美国工作”27人;“非美国出生+美国求学+美国工作”8人;其他6人,这6人中有4个英国人,1个荷兰人(1972年Dijkstra),1个以色列人(1996年的Amir Pnueli)。
  2001-2019年间,非美国获奖者多了起来。共30名获奖者,其中“美国出生+美国求学+美国工作”18人,“非美国出生+美国求学+美国工作”3人,其他9人。

  Dijkstra简历:
  1952–1962:荷兰阿姆斯特丹计算机部,程序员
  1962–1973:荷兰埃因霍芬理工大学数学系,教授
  1973–1984:美国Burroughs Corporation公司,研究员
  1984–2000:美国德克萨斯大学奥斯汀分校,教授

1、引子
  大部分计算机学生是在学习“Dijkstra最短路径算法”时得知Dijkstra的。图论中有两个著名的算法:Dijkstra最短路径算法和Prim最小生成树算法2。两个算法的思想基本一样,都是基于贪心法来扩展结点,执行步骤十分相似,代码只有微小差别。两个算法简单而高效,现在仍广泛应用在图问题中,例如手机的地图导航、游戏软件的寻路等。

  这两个算法虽然以发明者的名字“Dijkstra”、“Prim”命名,但其实有好几位科学家独立发明过,其中一人是Dijkstra。1956年,他26岁做兼职程序员时曾在一篇论文中同时提出了这两个算法。这篇只有3页的小论文“A note on two problems in connection with graphs3”,第一部分现在一般被称为“Prim最小生成树算法”,第二部分现在一般被称为“Dijkstra最短路径算法”。

  Dijkstra最短路径算法的思路很简单,它维护两个集合:一个是已经计算出最短路径的结点集合A,另一个是这些点向外扩散的邻居结点集合B。算法的执行步骤是:扩展A的直连邻居,放到B中;每次从B中取出距离起点最短的结点,放到A中;当B为空时计算结束。

图1 Dijkstra原始论文中的集合A和集合B

  不过,论文中没有提到一个关键问题:如何高效地从B中选出距离起点最短的那个点?这个问题的解决决定了算法的复杂度,决定了代码的效率有多好。现在学过图论的学生都知道,编程时一般用优先队列(效率极高,n个数只需要计算logn次就能找到最小的数)来实现。但是在Dijkstra的论文中,并没有提到如何实现,也许他认为这是一个需要扩展的问题,更大的可能是那时候还没有这些数据结构的概念。
  Dijkstra在1956年时发明了这个算法,但那时还没有自动计算方面的专业期刊,无法发表,直到1959年才找到合适的刊物发表。这篇论文是1945-2000年间Web of Science数据库中的一篇经典引文。在一次关于Dijkstra算法的通信中,Douglas McIlroy教授谈到了Dijkstra算法表达的现代性,指出“它在当时显然是不寻常的。后来的上千次引用也不能对它有所改进。”也就是说,Dijkstra在计算机科学理论初创时期所写的论文,已经十分规范而标准,并成了后来者的模板。
  Dijkstra对计算机学科的发展有很多奠基性的贡献,最短路径算法只是他年轻时走过的一个小脚印。Dijkstra于1956年提出最短路径算法,时年26岁,是他作为一个计算机科学家的开端。之后的30年,他发展了现在众所周知的、成为常识的多种计算机概念和技术,他那“巨人的肩膀,扛起了计算机科学4(The Man Who Carried Computer Science on His Shoulders)”。

2、生平
  简单地概况Dijkstra的成功而完美的人生:书香门第、天资聪颖、勤学好思、抓住机遇、工作努力、广泛交游。
  1930年,Dijkstra出生于荷兰城市鹿特丹(Rotterdam),是四个孩子中的老三。他有个好家庭。他父亲是中学化学老师和中学校长,但不是一个普通的化学老师,而是一个化学家、荷兰化学学界的名人,当过荷兰化学协会的主席,博学多才。他母亲是数学家,不过没工作而是家庭妇女(那个年代的女性都这样),她非常聪明,是个天才,Dijkstra说他从母亲那里学到了如何简洁优雅地解决问题。
  Dijkstra又聪明又勤学,学习成绩非常好。中学毕业后,他想去学法律,将来到联合国为世界和平做贡献,避免再次世界大战!但是身为科学家的爸妈都建议他,不要浪费自己的聪明才智,应该去从事科学事业。
  1948年,他到离家不远的莱顿大学(University of Leiden)读物理学,他说他的大学生涯“很穷很累很快乐5”。这不奇怪,那时正是二战后的欧洲重建时期。

  大学的头三年,Dijkstra还是那么勤奋,他老老实实学物理和数学,1951年通过中期考试,比其他同学都早。然而Dijkstra一直到1956年才拿到大学学位,一共读了8年大学。读了这么久,不是因为去游戏人生了,而是因为他对物理的兴趣衰退了,中间去兼职工作当了一名程序员。
  1951年,一件事改变了Dijkstra的命运。计算机科学的一颗星星开始升起,这将是一颗星等为一等的亮星。
  这一年,他那热爱科学并积极关注科学发展的老爸,看到剑桥大学的一个编程课广告,一门三星期的短课,学习EDSAC计算机编程。EDSAC是世界第一台存储程序式电子计算机,采用了冯诺依曼结构。冯诺依曼结构后来成为现代计算机的标准架构,可见EDSAC是当时最先进的计算机。作为对Dijkstra提前通过中期考试的奖励,父亲资助他去英国学编程。估计真实目的是让他去剑桥大学见见世面,将来去剑桥读读研究生,顺便路过伦敦逛逛看看花花世界。
  好学的Dijkstra第一时间想到的是:用计算机来帮助做数值计算,有利于物理研究!Dijkstra高兴地去学编程了,从此与计算机结缘,走上了康庄大道。
  Dijkstra在这门编程短课上似乎发现了新大陆,学得如鱼得水。而且,他偶遇了荷兰阿姆斯特丹数学中心的负责人,获得了一个“黄金就业机会”。负责人对21岁的大学三年级青年说:计算机刚起步,有光明的发展前景,注定成为一门显学,“小伙子你会成为计算机宗师的”。然后热情邀请他到数学中心做编程工作,而且宜早不宜迟,机会不等人,“快来快来,过几天就没位置了”。
  Dijkstra面临一个重大选择,是继续读物理,还是去搞编程?他决定一起做。而且,大学生活穷得很,兼职能赚点钱,有钱才能找女朋友!
  从1952年开始,Dijkstra大部分时间都在数学中心兼职搞编程,物理学业差不多荒废了,导致他到1956年才从大学毕业。毕业后,他开始在数学中心全职工作,一直到1962年。长达十年的编程工作,他自学成才,成长为一位计算机科学家。
  他在自传中戏称自己是“第一个靠编程赚钱的荷兰人6”,在图灵奖获奖感言中也说自己是荷兰的第一个程序员。

  看到这里,我们发现Dijkstra当初其实是被数学中心负责人忽悠了。荷兰那时几乎没有人会编程,连一个只学了3周编程的Dijkstra也成了稀缺人才,甚至是“荷兰第一个程序员”。数学中心的负责人之所以向Dijkstra伸出橄榄枝,根本原因是没有选择,只能找他。
  在数学中心当程序员,听起来不错:敲着键盘,喝着咖啡,工作之余还能打打游戏…这都是做梦,那时还没有电脑键盘,输入靠穿孔纸带,输出靠电传打字机,电脑屏幕自然也没有。至于编程嘛,高级语言还没有出现,汇编语言也没有,因为电脑还没有编译编程语言的能力,只能直接用机器码编程,就是0和1,也就是在纸带上穿孔,打孔就是1,没打孔就是0。没学过计算机的人可能不能理解为什么“0101110011…”这种东西就是程序。现在编程语言教科书上的知识,当时几乎都没有。
  Dijkstra在剑桥学的就是这种编程,怪不得只要3周,因为也没什么好学的。据我猜想,这3周的教学大纲估计长这样:第一课“二进制”;第二课“逻辑代数”;第三课“逻辑电路”;第四课“加法器电路”;第五课“冯诺依曼结构”;第六课“机器指令”;第七课“穿孔技巧”;第八课“故障和维修”;完。
  Dijkstra没有被这种枯燥的学习吓倒,反而产生了浓厚的兴趣,数学中心负责人肯定高兴坏了。
  Dijkstra在数学中心的十年编程工作颇有成效,最短路径算法就是这个期间发明的,这是Dijkstra设计的第一个著名算法,并以他的名字命名。Dijkstra为此感到很得意,他在1993年的自传中回忆这一美妙时光:“最短路径算法以我的名字命名,让我出了名。当初我设计这个算法的时候,并没有拿着纸和笔冥思苦想。那是在阿姆斯特丹的一个露天咖啡馆,我和妻子(当时在谈恋爱,一年后的1957年结婚)晒着阳光喝着咖啡,然后我灵机一动想到了这个算法。”谁还没有一个春风得意的年轻时代呢。

图2 Dijkstra在自传中提到最短路径算法

  1960年,Dijkstra和同事一起编写ALGOL 60编译器,这是世界上第一个ALGOL 60编译器。开发过程中解决了很多关键问题,例如1960年Dijkstra在一篇论文“Recursive Programming”中,提出了术语“堆栈(stack)”。多年以后,他得知这篇小论文让他在美国计算机学界出了名。

图3 Dijkstra在自传中提到stack

  因为在数学中心的工作,Dijkstra于1959年获得了阿姆斯特丹大学的博士学位,博士论文题目是“Communication with an Automatic Computer”,研究实时中断问题。
  Dijkstra在数学中心工作到1962年,这期间的工作让他成为一位有名的计算机科学家,他这颗星星开始在天空眨眼。
  1962年,他被聘为荷兰埃因霍芬理工大学(Eindhoven University of Technology)数学系的教授。不过,他谦虚地说自己其实是第3个候选人,只是因为前2人拒绝了聘请,才轮到他。学校给他安排的本职教学工作是上《数值分析》课,课余他的精力完全在计算机上,他组织了一个计算机研究小组,开发操作系统“THE Multiprogramming System”。“THE”系统创造了历史,是世界第一个松耦合、显式同步、协操作串行处理的操作系统,在大学的计算中心运行了10年。信号量(semaphore)、死锁(deadlock)等新概念就是在这个系统上提出的。他很为这个系统自豪,他到英国、美国交流这个系统的设计,获得了同行的高度认可,使他在计算机学界声名鹊起。
  Dijkstra最广为人知的事情,是他对GOTO语句的批评。当时人们在编程时,经常使用GOTO语句,随意跳转到程序的任意位置。“GOTO语句,天马行空!” 这个语句极为暴力,让程序的流程变得支离破碎。敏锐的Dijkstra第一个认识到这个语句对程序逻辑、计算资源的的破坏性。1968年他给 Communications of the ACM写了一篇2页纸的通讯,信件原标题是“反对GO TO语句(A case against the GO TO statement7)”,因为标题过于露骨,被编辑改名为较为温和的“Go To Statement Considered Harmful”后发表,引起了广泛的争论。当然,现在大家都知道他赢了,几乎没有人在编程的时候使用GO TO语句。这封信影响如此之大,以至于“X considered harmful”成了一个标题模板,经常被用于咆哮和指责的文章中。

  1969年,杰出的计算机科学家Dijkstra很郁闷:他不受自己工作的大学的待见,他的研究小组被解散。他为了平复自己郁闷的心情,躲起来花大气力写了一篇80多页的报告“Notes on Structured Programming8”,即“结构化编程”。结构化编程现在是计算机程序默认的基本原则,不过那时还是一个全新的概念。

  Dijkstra还没意识到他写了一篇辉煌的巨著。他觉得这只是一篇普通的报告,让大家看看就好了,于是复印20份,寄给了外国的计算机科学家朋友们。然而出乎他的意料,这篇报告获得了巨大的成功,“像野火一样传播(spread like wildfire)”,辗转复印了很多轮,Dijkstra自己就认识一个住在偏远角落的人珍藏着这篇报告的第5、6代复印稿。可以计算一下,如果每人复印20份然后继续往下传,第5代就有 2 0 5 = 300 20^5=300 205=300万!“洛阳纸贵”,一时间搞计算机的人人都在看这篇伟大的报告,深深为Dijkstra充满哲人的洞见而折服。Dijkstra后来分析为什么受到欢迎:“这是第一篇严肃讨论编程挑战的文章。”
  这份报告终于奠定了Dijkstra计算机科学巨星的地位。
  Dijkstra声誉日隆。1972年的一个下午,他正坐在学院的办公室发呆,突然接到一个美国电话,被告知获得了第七届ACM图灵奖。Dijkstra非常震惊,反复确认才肯相信。他完全没想到自己能得这个奖,因为前6个图灵奖获得者都是讲英语的、工作于著名机构的美国人或英国人。他幸福地眩晕了(I got even a bit overwhelmed)。
  Dijkstra的震惊是可以理解的,如果他晚一些年获得图灵奖,他会更加震惊,因为一直到24年之后的1996年,才有第2个非英美的获奖者。姚期智2000年获得图灵奖,是图灵奖唯一的华裔学者,当时他是美国国籍。姚期智于2016年放弃美籍,成为中国公民。
  然而,Dijkstra在学校的地位却越来越尴尬。就在获得ACM图灵奖之后不久,他被迫从大学离职了,这事儿真让人啼笑皆非。大环境是计算机学科在1960年代中期才在英美的一些大学出现,而Dijkstra所在的大学那时还没有。他所在的数学学院的领导并不理解和支持他的计算机工作,觉得他不务正业。他搞的计算机研究,和学院其他老师做的数学研究似乎毫不搭边。另外,Dijkstra在自传中用忧郁的语气回忆自己当时“穿拖鞋、留胡子、态度傲慢”,这不修边幅的样子一点儿都不像个教授,倒是个“完美的”现代程序员的邋遢风格。Dijkstra的人缘似乎不太好,他成了他所在大学的一个异类,学校甚至解散了他的研究小组,他成了一个孤家寡人。
  甚至1972年获得图灵奖,这个荣誉也没有让他在学校的地位有所好转。Dijkstra在办公室接到获奖电话,从幸福的眩晕中恢复过来后,第一时间就跑去告诉院长,“我得图灵奖啦!”然而院长大人似乎不知道什么是图灵奖,还脱口而出说了一句伤人的话:“你们搞计算机的,得奖不要太容易哦!(In the world of computing, they are rather lavish with prizes, aren’t they?)?” 年轻的科学巨星、计算机宗师被说得如此不堪,Dijkstra刻苦铭心地记了一辈子,还写到了自传中。不久后,他从大学离职了。
  1973年8月1日,Dijkstra找了个新工作,新东家是当时著名的美国计算机制造商Burroughs Corporation公司,办公地点就在他荷兰的家里。这是一份美妙的工作,他没有具体任务,而是“自由研究”,只需要每年去美国总部汇报几次就好了。在做“自由研究员”的那些年,他跑遍了世界各国,参加各种学术会议,在计算机的世界中自由飞翔。
  然而,美妙时光不会永远持续。1984年,他从Burroughs Corporation公司离职,因为“Burroughs的学术视野正在缩小,而我的视野正在扩大(Burroughs’s intellectual horizon was shrinking, my own was widening)。” Burroughs Corporation公司在走下坡路,日子不好过开始节流了。
  美国的好客和学术环境吸引着Dijkstra。1984年,他终于在54岁的年龄离开了荷兰,到美国德克萨斯大学奥斯汀分校做计算机教授。
  Dijkstra1999年退休,2002年查出癌症,回到荷兰后不久去世。
  Dijkstra一生著述极多。他做事非常有条理,用自己名字的缩写“EWD”对这些文件进行命名和编号,一共有1318篇,德克萨斯大学把这1318篇作品整理成档案在网上公开。有趣的是,他是一位计算机科学家,却几乎不用电脑打字,而习惯于用钢笔书写。这1318篇作品,除了早期的一部分已经找不到手稿是打印的,后期的手稿都在,字迹工工整整,几乎没有涂改的痕迹。这些手稿的笔迹,数十年完全一致,显然出自同一人的手笔,不是别人誊抄的。有的手稿长达几十页,是很不容易的。
  他的最后一篇“EWD1318”,写于2002年4月,当时已经回到荷兰。他4个月后去世。
  绚烂的生命之花,在日暮时分凋落。

图4 最后的手稿:EWD1318

  
  本文参考了以下原始资料:
[1]Dijkstra自传:https://www.cs.utexas.edu/users/EWD/ewd11xx/EWD1166.PDF
[2]Dijkstra档案:https://www.cs.utexas.edu/users/EWD/
[3]ACM图灵奖介绍:https://amturing.acm.org/award_winners/dijkstra_1053701.cfm


  1. https://www.phrases.org.uk/meanings/268025.html ↩︎

  2. R. C. Prim, “Shortest Connection Networks and some Generalizations,” Bell System Technical Journal, Vol. 36, 1957, pp. 1389-1401. ↩︎

  3. Edsger W. Dijkstra, “A note on two problems in connection with graphs,” Numerische Mathematik 1, 1959, pp. 269–271. 下载:http://www-m3.ma.tum.de/foswiki/pub/MN0506/WebHome/dijkstra.pdf ↩︎

  4. The Man Who Carried Computer Science on His Shoulders
    https://inference-review.com/article/the-man-who-carried-computer-science-on-his-shoulders ↩︎

  5. Dijkstra自传:“We were very poor, …, but life was incredibly exciting.” ↩︎

  6. Dijkstra自传:“the first Dutchman with the qualification ‘programmer’ on the payroll.” ↩︎

  7. A case against the GO TO statement https://www.cs.utexas.edu/users/EWD/ewd02xx/EWD215.PDF ↩︎

  8. “Notes on Structured Programming”: https://www.cs.utexas.edu/users/EWD/ewd02xx/EWD249.PDF ↩︎


http://www.ppmy.cn/news/248043.html

相关文章

SoildWorks画草图拖影问题

20220103 - 20230324 By wdhuag 前言: SoildWorks2021在新3060显卡的笔记本上画草图会有拖影。。 参考: SolidWorks这种残影怎么解决? - 知乎 solidworks画图时候出现了拖影现象,有人遇到过类似问题嘛? - 知乎 so…

鬼灭之刃人物炫酷高清壁纸

时值日本大正时期。 传说太阳下山后,有恶鬼出没吃人。 亦有猎鬼人斩杀恶鬼、保护人们。 幸福被破坏之时,总是弥漫着鲜血的味道。 纵然我身俱灭,定将恶鬼斩杀! 血风剑戟冒险谭,开幕! 你是否也同我一样…

nginx系列第六篇:结合nginx梳理linux中信号的使用

nginx中master进程来管理整个nginx工作的全过程,运行时其通过接收外部信号输入的方式来对内部进行相关调整。本文对照nginx来梳理一下linux中信号常用API的使用。 目录 1.函数sigaction和signal 2.关于信号集sigset_t 2.1 测试程序1 2.2 测试程序1 3.信号屏蔽…

前端基础(JavaScript)——基础语法(变量,分支...) Json对象【重要】 函数定义 事件(未完待续)

目录 引出JS是啥,能干啥基础语法1.变量----let2.怎么打印---console3.if条件分支--啥都可以是条件例子:输入框,打印输入和未输入4.数组push 和 splice(2)splice,3个参数,索引开始、删除几个&…

第二章:MySQL环境搭建

第二章:MySQL环境搭建 2.1:MySQL的下载、安装、配置 MySQL的四大版本 MySQL Community Server社区版本:开源免费、自由下载,但不提供官方技术支持,适用于大多数普通用户。MySQL Enterprise Edition企业版本&#xff1…

jmeter打开文件时报cannot read value = ::{20d04fe0-3aea-1069-a2d8-08002b30309d}\::{5fcd4425-ca3a-48f4-a57c-

引发问题原因未知,但是通过百度找到解决方法 WARNING: Cannot read value ::{20D04FE0-3AEA-1069-A2D8-08002B30309D}\::{5FCD4425-CA3A-48F4-A57C-B8A75C32ACB1} java.io.FileNotFoundException: File C:\apache-jmeter-5.4.1\apache-jmeter-5.4.1\bin\::{20D04F…

Java中使用A标签出现“%20d“等字符解决方法

在使用超链接时从配置文件中获取的地址,在通过${“value”}注入后多出了其他的字符,在此记录一下. 多出字符的原因是将URL中多余的空格进行了转义. 解决办法也很简单, 将url重新进行编码 URLDecoder.decode(URL,"UTF-8");提醒一下, 代码中使用decode方法的时候需要抛…