这是我的湛庐课程《给技术人的职场突围课》 (链接) 的一部分。 这篇文章也是 IT 女神征文活动 的一部分。

《编程人生》是一本优秀程序员的采访集,里面记录了15位世界级编程大师的故事。

我在 发刊词 里面说过,在这个书单课里,我会通过对四种关系的梳理,帮你系统思考自己的职业发展。而在这几种关系中,最基本的一个,就是要处理好“我和自己的关系”,更好地认识自己。

女程序员先驱( IT女神)

我之所以选《编程人生》 (原名:Coders at Work)这本书,就是想通过书里这些优秀的软件工程师、科学家的例子,“以人为镜”,从比较务实的层面,和你聊聊怎么去清晰地认知自己,发掘自己的性格特点,选择适合的职业发展路径。我也写了一篇这本书的读后感。

《编程人生》这本书采访了 15 位优秀的程序员,我不能一一介绍,那从什么人开始介绍呢? 编程可以说是一个工程,是一门艺术,也可以说一门手艺。 作为一个行业,我们现在的很多习以为常的规矩和做法,是怎么来的?这个行业的先驱们是在什么样的条件下创立这个行业的各种规范的?我们叫他们‘祖师爷’,或者在我们这一集里面,叫她们‘祖师奶奶’。 我想从最年长的程序员说起,在这本书里,就是 Fran Allen。

(注:我搬运了几张网上的照片,例如https://blog.csdn.net/rx3oyuyi/article/details/88342230)

Fran Allen

Fran 1932 年出生,2020 年去世,她是美国早期计算机程序员和科学家。这样一位“元老”级别的程序员,她的工作和我们现在的计算机、软件工程发展有什么直接关联么?

答案是,不仅有,而且有很大的关系。她的研究对于现在Java 等语言的即时编译 (Just In Time, JIT)技术起了奠基作用。 2002年时,Fran Allen 还凭借 “在优化编译器技术的理论和实践中的开拓性贡献” 获得了图灵奖。 她是七十多位获得者中仅有的两位女性之一。

Fran本人并不是计算机专业毕业的,她有数学的本科学位,还辅修物理学课程,除此之外,她只是在读数学硕士学位的时候,选修过计算机技术的课程。

她毕业时,正赶上 IBM 招聘,因为觉得计算机很有趣,加上着急要还助学贷款,所以她就填了申请,此后一段时间,其他的工作机会迟迟没有出现,她就答应了 IBM 的 offer。

她在1957 年加入 IBM ,开始了自己的程序员生涯,一直在 IBM 工作了 45年,直到退休。作为一个并非科班出身的人,Fran是怎么学习计算机技术呢” />Ada Lovelace

或许很多人不知道,历史上的第一位程序员,就是一位女性,她叫Ada Lovelace ,是英国著名诗人乔治·拜伦的女儿,在母亲的鼓励下,阿达从小就喜欢数学,在1842年与1843年其间,Ada为发明家巴贝奇(Babbage)发明的分析机编写算法,她详细说明用计算机进行数学的运算方式,这样的描述,被认为是世界上第一个计算机程序;她还提出了循环等编程的基本概念。 她曾经对计算机做了预言,说“这个机器未来可以用来排版,编曲或是各种更复杂的用途”。

Grace Hopper

如果说Ada作为“程序员”并没有一个现代的计算机作为基础来编程,那么,在一百年后,1944年,第一个能实际运行并被编程的计算机 Mark I 在美国哈佛大学诞生,时年三十七岁的格蕾丝·霍珀(Grace Hopper)女士就是它的第三个程序员,她和她的团队在Mark I 上实现了100年前阿达提出的循环,子程序,还有其他现代编程的概念和实践。 例如“回滚机制”,让出问题的程序能返回到一个出问题之前的状态,这种实践在现在的互联网公司的运维体系中还在运行。

那年的秋天,她们的工作吸引了另一个数学家和计算机科学家冯 · 诺依曼的注意。 在研究了 Mark I 和另一个早期计算机 ENIAC 的技术和架构的特点后,冯 · 诺依曼在第二年提出了划时代的 “冯·诺依曼体系”,奠定了现代计算机的体系机构的基础。 根据霍珀的回忆,当时大部分的计算机研究都是在美国军方的资助下工作,对于公开发表文章都有很多限制。冯 · 诺依曼的文章是建立在这些一线程序员和研究员的工作之上的第一个公开发表的文献。

这里还有一个有趣的小插曲,我想你可能也听说过,就是霍珀在软件设计领域的第一项重大“发明”,是创造出了一个著名的计算机术语——“bug”。

1946年,她在发生故障的MarkⅡ计算机的 继电器触点 里,找到了一只被夹扁的小飞蛾,正是这只小虫子“卡”住了机器的运行。霍珀顺手将飞蛾夹在工作笔记里,并记录下这是一个真正的“bug”。后来这演变成计算机行业的专业术语。我们现在在网上,还可以查到这个最早“bug”的照片。

虽然现代电脑和飞蛾再也没有什么关系了,大家还是习惯地把排除程序故障叫做Debug(除虫)。

在早期的工作中,大家注意到一个问题。计算机代码,是给计算机读的,还是给人读的? 在计算机的早期,计算机的指令都是用二进制或者八进制的数字表示的。机器只认识这些数字,所以对于机器来说,挺方便的。 霍珀和其他程序员在实践中发现,程序员要花很多时间来记忆,修改,和讨论程序,一行一行的数字,并不利于人类设计,改进和交流程序,于是,霍珀和她的团队做了一系列的改进:

  • 第一,用英语字母来表示计算机指令,这样程序员就能方便地阅读和理解。
  • 第二,她也是第一个在源程序上写注释的程序员,这个成为了现在计算机编程的规定动作。
  • 第三,“一图胜千言”,她们发明了流程图 (Flow Chart),使用矩形来代表操作,使用菱形来代表选择,用线来表示程序的状态。就是从1940年代末开始的。一直到 70 多年后的今天,初学者还是用流程图来帮助设计和理解程序。

沿着 “让计算机程序容易写,容易理解” 的思路, 在1950年代末,霍珀还领导设计了现代编程语言 COBOL, 这个基于英语的计算机语言广泛地用于商业领域。 当时的计算机存储器非常贵,为了节省空间,COBOL 语言用六位字符来存储日期, 即年,月, 日各两位。 过了近四十年,世界上还有很多 COBOL 语言写的程序在运行,但是随着 2000 年的到来,用两位数记录的‘年’会变成 00, 这样就和 1900 年分不清了。这就是著名的 ‘千年虫’问题,这也从一个侧面说明了她设计的这个语言的长寿和应用广泛。

讲到这儿,有听众会问,这是不是有意要推崇女性的贡献呢?其实这个行业在早期发展的时候,没有人深入考虑过IT行业有多大的前景,在选择的时候,能干活就行,所以不管是男生女生,能解决问题就好,从我自身的经历来看,在计算机领域做出优异的成绩,和性别没有什么关系。

IT 行业提供了特别广泛的机会,各种不同的性格特点的人,都能找到自己的发挥空间。而且程序写出来之后,是没有性别的,大家只能看见程序的正确性、稳定性,所以只要技术过硬,无论男女,无论性格怎么样,都可能取得成功。

当然我在这儿说的成功,不是要给你灌鸡汤,我们总说:“这个世界上只有一种成功,就是以自己喜欢的方式过一生。”例如,我喜欢热情,不拘一格的生活方式,这没问题。但是,我们并不是自己性格的奴隶,不拘一格并不是 “由着自己的性子”。

Silvia

我想起一个同事,我的一个经理 Silvia (西尔维亚)。 她是从巴西来到美国微软公司工作的,她有南美女性的那种外向的热情性格,但是工作非常细心。 例如,我们软件工程师经常签入代码,很容易导致在主分支上的代码编译不过。我自己也曾犯过这样的错误。 在微软团队里面,如果你的代码签入导致了主分支的错误,你要去做 Build Master ,又叫“构建大师”,就是在本职工作之外,处理很多和代码构建相关的工作,直到下一个犯错误的人出现。 但是西尔维亚在微软作为一个资深的开发人员,就是没有犯过一次错误,没有做过一次 Build Master。 在工作之余聚会聊天的时候,我们都非常佩服她。

总结这一讲,我们讲了计算机软件行业几位老前辈的故事。 回到我们故事的主人公,我们有这样的问题:

如果你获得了数学系的博士,并且是大学里受欢迎的数学讲师了,就像我们前面说的格蕾丝 · 霍珀那样。 但是你的工作需要你学全新的硬件,和一个全新的“编程”的东西,你会怎么看这个机会?怎么选择?

如果刚一上班,一个身材魁梧不苟言笑的同事就跑过来指责你的工作中的问题。你会怎么办?

欢迎你在评论区分享你的见解。

这是我的湛庐课程《给技术人的职场突围课》 (链接) 的一部分。