他是世界上最杰出的程序员,一个月写了个操作系统,退休后去做飞行员!

大家好,我是阳哥。

1983年,美国计算机协会将图灵奖授予肯·汤普森和与丹尼斯·里奇。

获奖理由是:“For their development of generic operating systems theory and specifically for the implementation of the UNIX operating system.”

翻译过来就是:

“授予肯·汤普森和与丹尼斯·里奇图灵奖,以表彰其在通用操作系统理论领域的贡献,特别是UNIX操作系统的开发与实现。”

文章开头引用一段英文,是为了显得K哥有文化,不过这些都不重要,本文将要介绍的这位,才是真正的牛逼,大神中的大神。他就是,UNIX之父、Golang发明人之一,肯·汤普森。

在许多读者都还没出生的年代,肯·汤普森就已经取得了计算机界的最高荣誉--图灵奖。

ecf7bccc6b1bb25b63c7359950110fbb.jpeg


01

计算机天才养成记

肯·汤普森出生于1943年。在他小学的时候,有一堂课讲到了二进制,喜欢逻辑的他立刻被吸引住了,在兴趣的驱使下,他做了很多相关的二进制计算,并借助一台十进制计算器将其扩展到各种进制。

其实,K哥小时候也有类似的经历,我上初中的时候对物理非常着迷,很早就开始研究,牛顿的头发是在哪烫的?我想,我的物理老师,就是从那个时候开始有心理阴影的。

肯·汤普森,从小就是妥妥的学霸一枚,边玩边学,轻松考上了加州大学伯克利分校,攻读电子工程学士学位。

虽然,国外的大学不像国内这么轻松,随便放飞自我。但是,对于肯·汤普森这样的大神来说,课程so easy,哪里不会点哪里。

于是他迷上了一个新玩意:计算机。

每天晚上,趁着没人的时候,他就偷偷溜进机房,自学了编程,编写游戏、玩游戏,嗨到不行。

大四那年,大神心里还是有点B Tree的,因为觉得自己不务正业,都在玩游戏和编程,电子工程没怎么好好学,所以没有申请读研究生。

正当他准备卷铺盖毕业的时候。一位教过他的老师Berlekamp教授替他申请了研究生,并且通过了,多好的教授啊!

回想起K哥大学时候的教授,我的论文改了八回,答辩两次才勉强毕业。同样都是教授,怎么差别就这么大呢?当然了,同样是学生,差别是有点大。

读研究生的时候,肯·汤普森只用了一年就毕业了。是的,你没看错,他TM只用了一年就拿到了电子工程和计算机科学的硕士学位。


02

加入贝尔实验室

研究生毕业后,肯·汤普森的才华惊动了当时大名鼎鼎的贝尔实验室,并且向他伸出来橄榄枝。但是,肯·汤普森却看不上,他心想我这么年轻,这么有才华,还有头发,应该有机会改变世界的。

但是,在贝尔实验室的再三邀请之下,他还是勉强答应去参观一下。


这一参观不要紧啊,他发现汉明码发明人、信息论发明人、晶体管发明人......这些牛逼闪闪的人物,都出自贝尔实验室。

肯·汤普森心想,像我这样的天才不就应该来这里吗?于是他接受了贝尔实验室的Offer。

33db98e03b6e667e6dd6cfaf93a259cb.jpeg

贝尔实验室


03

搞砸 “Multics操作系统”项目

1966 年,肯·汤普森加入贝尔实验室,与丹尼斯·里奇(C语言发明人)一起参与名为 “Multics操作系统”的项目开发。

那个时代的计算机系统还处在批处理的阶段,只能在既慢又笨重的大型机器上工作,要先将程序卡片装入设备,然后等1个小时后才能取运算的结果。不仅慢,还很废纸。

因此,贝尔实验室联合麻省理工学院,以及通用电气公司,想建立一套可以多人使用、多任务、多层次的 Multics 操作系统。

但是,由于大家太过追求完美,导致开发周期过长,成本高,短期内看不到产出。可惜那个年代还不流行敏捷开发的理念。

1969 年的时候,贝尔实验室忍无可忍,决定退出这个项目。

4de883e6e8f98615d081ba10bd86be78.jpeg

对于程序员来说,搞砸一个项目是很稀松平常的事情,就像K哥这10几年的职业生涯里搞垮过的项目,都可以写出60多篇“搞垮系列”了。


肯·汤普森也很失望,但是让他失望的不是搞砸项目本身,而是他再也不能玩自己写的名为“star travel”的游戏了,因为这个游戏完全是基于 Multics 的。你看看大神,玩游戏才是主业,上班只是副产品。

dc9e7a0bc239f7298abe3436e0c93f34.jpeg


04

为了玩游戏,开发了UNIX

既然这样,那就自己开发个操作系统吧,这样就可以继续玩游戏了。


技术好就是任性啊,一言不合就开发个操作系统。所以千万不要把程序员逼急了,他们连操作系统都能做,还有什么事情做不出来?


肯·汤普森找到了一台废弃已久的老式 PDP-7小型机,虽然称为小型机,那时候也有一个房间那么大!在这台机器上他首先重写了游戏,游戏有了后,肯·汤普森还想着要开发一个全新的操作系统。

正好这个时候,他的老婆带着孩子回娘家住3个礼拜,也就是说他有完整的3个礼拜没有人打扰的时间。

于是他决定利用这段时间开发操作系统,基于之前搞砸“Multics系统”的经验,他很快完成了内核系统、文件系统、编辑器、编译系统,一个月时间竟然编写完了操作系统的内核。

这个故事告诉我们,一个男人想要搞大事,老婆不在家是多么的重要!K嫂你看到了吗?K哥一把年纪一事无成,是有原因的。一天查岗八回,能写出个屁才怪呢。

话说这个系统做完后,肯·汤普森将其命名为 UNiplexed Information and Computing System,缩写为 UNICS 。但是怎么念都拗口,后来改名为UNIX,陆续做了一些改动后,第一版UNIX操作系统诞生了。

3fd2b107452962ef7125cdcee9dce26f.jpeg

那一年,肯·汤普森 26岁。


05

UNIX 跟C语言更配

1973 年的 10 月,在 IBM 举办的操作系统原理专题研讨会上 ,UNIX首次向世界问好,当肯·汤普森和与丹尼斯·里奇向人们宣读论文并展示了UNIX后,整个会场轰动了,人们惊呼:卧槽,牛逼,还能这么玩!


后来随着UNIX的用户越来越多,肯·汤普森和与丹尼斯·里奇决定将UNIX进一步改写,以便可以移植到各种不同的硬件系统。


由于UNIX的源码中不少是用汇编完成,不具备良好的移植性,正好丹尼斯·里奇在 1973 年在 B 语言的基础上开发出了 C 语言。C 语言灵活,也更高效,与硬件无关,并且不失其简洁性,正是UNIX移植所需要的法宝。

于是旧版的UNIX与 C 语言完美结合在一起,产生了新的可移植的UNIX系统。随着UNIX的广泛使用,C 语言也成为了当时最受欢迎的编程语言,一直延续至今。

ef2fc119d12f644d9c637bc969fc5ad8.jpeg

UNIX经典的设计哲学KISS,就是在那个时候被提出来的——Keep It Simple, Stupid。


06

黑客与“后门”

肯·汤普森还有一个备受争议的行为,就是在UNIX里留后门。是的,这哥们竟然在代码里下毒。

最开始的时候,UNIX系统在贝尔实验室是供大家免费使用的。有人发现,肯·汤普森总能进入每个人的账户,于是一位同事就分析UNIX代码,重新编译了系统。

令人意想不到的是,肯·汤普森还是能进入他们的账户,贝尔实验室的科学家们却对此束手无策。


直到1983年,肯·汤普森在他的图灵奖获奖感言里揭示了这一秘密,原来,让他轻松“侵入”各位同事账户的秘诀不在UNIX代码,而在编译UNIX代码的C编译器里,而肯·汤普森正是编译器的开发者。这个操作666,你以为看透了大神,可你就是玩不过他。

那位头发比他多,胡子跟他一样长的自由软件之父、著名黑客--理查德·斯托尔曼,曾这样定义过黑客,一名黑客必须包含三个特点:好玩、高智商、探索精神,而且三项必须同时满足。

黑客追求的不是实用性技术或金钱。K哥作为一名技术从业者,经过多年的努力,我已经满足了黑客精神的其中一点:好玩。当然了,主要是被别人玩。

d82d7e792815346f335264676f673c76.jpeg

自由软件之父 理查德·斯托尔曼

或许从这个角度,更能理解肯·汤普森的行为,他并非违背了道德准则,对他来说这个事就是一逗乐。不难发现,黑客的价值观跟德云社还挺配的。


07

加盟Google,参与Golang语言开发

2000年,57岁的肯·汤普森在贝尔实验室退休。是的,这哥们的整个职场生涯都是在贝尔实验室度过的,期间有几年去了大学教UNIX系统课程。

然而,退休后这位老爷子也闲不住。


2006 年,肯·汤普森加入了 Google 公司。看看吧,谁说程序员做到35岁以后就找不到工作?关键还是技术过硬,别做了10几年技术还是写CRUD。玩技术的要么越钻越底层,要么就高屋建瓴搞架构,千万别原地踏步。

加入谷歌后,肯·汤普森又搞了一件大事。

他跟其它优秀的科学家一起开发了Go语言,也就是Golang。主要开发者有:肯.汤姆逊(Ken Thompson)、罗布.派克(Rob Pike)和罗伯特.格里泽默(Robert Griesemer)。另外两位也是大神,有机会再仔细写写。

Go语言不用多介绍了,有人形容Go语言:Go = C + Python , 说明Go语言既有C静态语言程序的运行速度,又能达到Python动态语言的快速开发。

国内不少科技公司都是Go的拥护者。比如七牛云的CEO许式伟,就是国内较早一批Go的使用者。许老板早年刚创业的时候,来K哥所在的公司做过技术交流,我作为公司代表接待过他,算是有一面之缘吧。


08

写最骚的代码,开最酷的飞机

除了写程序之外,肯·汤普森是一位狂热的飞行爱好者,并且还获得了飞行执照。

闲暇之余,他会跟同事们一起自驾,来一场说走就走的飞行。你不用羡慕大神的生活,其实你也可以拥有,但首先你得有架飞机。

没有飞机也不用沮丧,说不定哪天,你用滴滴打飞机,就能叫到他。

0ad8116a4a1545d0353c8d95a3cadc06.jpeg

你以为大神光是开私人飞机就完事了?肯·汤普森就算是爱好也要玩到极致。

1992年他特意到莫斯科,玩了一把米格29战斗机。不想开战斗机的飞行员不是好骑手。有钱、有闲、有胆,就这么任性,你有办法吗?

a7f81bcfc2c7b6e2ad18bc1a10018e27.jpeg


09

结束语

肯·汤普森对计算机产业的发展,贡献是巨大的。不仅是UNIX系统发明人,在他的职业生涯里还开发了B程序语言(C语言的前身),UTF-8编码,ed文本编辑器,以及参与开发了Go程序语言。

除了获得图灵奖之外,他还先后获得了多项至高荣誉:

1994年,他获得了IEEE(电气和电子工程师协会)计算机学会先锋奖。


1998年,被授予美国国家科技奖章。


1997年,入选计算机历史博物馆名人录。

......

肯·汤普森的整个职业生涯,并没有像比尔盖茨、乔布斯等技术天才那样,走上创业的道路,赚很多的钱。他只呆过两家公司,所做的工作也是他一直热爱的编程工作。

最后,以作家罗兰的一句名言作为结尾,与你共勉:“成功的意义应该是发挥了自己的所长,尽了自己的努力之后,所感到的一种无愧于心的收获之乐,而不是为了虚荣心或金钱。”

-------- End --------

850b7be3cec32e80d344ab16b1b0e0c7.jpeg
精选内容
eb8be97058649233e8ab2492bf44a825.jpeg 44f459d4e891fd8b7ae5320ea0859122.jpeg
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的企业员工管理系统的C语言程序设计作业: 题目:企业员工管理系统 要求: 1. 实现员工信息的录入、修改、删除、查询功能; 2. 实现员工信息的打印功能,可以按照姓名、工号、职位等排序; 3. 实现员工工资的计算功能,包括基本工资、津贴、奖金等; 4. 实现员工考勤管理功能,包括请假、加班、旷工等; 5. 实现员工绩效考核功能,包括KPI、年度评估等; 6. 实现员工晋升、晋级、调整等管理功能; 7. 实现员工离职、退休、转岗等管理功能; 8. 采用文件存储方式,实现员工信息的永久保存; 9. 最好能够有图形化界面。 提示: 1. 可以采用结构体存储员工信息; 2. 可以采用链表、二叉树等数据结构实现员工信息的排序; 3. 可以采用文件读、数据库等方式实现员工信息的永久保存; 4. 可以采用QT、MFC等框架实现图形化界面。 参考代码: 由于该企业员工管理系统比较复杂,且需要涉及到多个功能,因此这里只提供一个简单的参考代码,供大家参考: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_NAME 20 #define MAX_ID 10 #define MAX_DEPARTMENT 20 // 员工结构体 typedef struct Employee { char name[MAX_NAME]; // 姓名 char id[MAX_ID]; // 工号 char department[MAX_DEPARTMENT]; // 部门 float salary; // 薪资 int attendance; // 考勤 int performance; // 绩效 struct Employee *next; // 指向下一个员工的指针 } Employee; // 用链表存储员工信息 Employee *head = NULL; // 打印菜单 void print_menu() { printf("=====================================\n"); printf("= 菜单 =\n"); printf("=====================================\n"); printf("= 1. 录入员工信息 =\n"); printf("= 2. 修改员工信息 =\n"); printf("= 3. 删除员工信息 =\n"); printf("= 4. 查询员工信息 =\n"); printf("= 5. 打印员工信息 =\n"); printf("= 6. 计算员工工资 =\n"); printf("= 7. 考勤管理 =\n"); printf("= 8. 绩效考核 =\n"); printf("= 9. 员工管理 =\n"); printf("= 10. 保存员工信息到文件 =\n"); printf("= 11. 从文件中读取员工信息 =\n"); printf("= 0. 退出 =\n"); printf("=====================================\n"); } // 录入员工信息 void input_employee() { Employee *new_employee = (Employee *)malloc(sizeof(Employee)); printf("请输入员工姓名:"); scanf("%s", new_employee->name); printf("请输入员工工号:"); scanf("%s", new_employee->id); printf("请输入员工部门:"); scanf("%s", new_employee->department); printf("请输入员工薪资:"); scanf("%f", &new_employee->salary); printf("请输入员工考勤:"); scanf("%d", &new_employee->attendance); printf("请输入员工绩效:"); scanf("%d", &new_employee->performance); new_employee->next = NULL; if (head == NULL) { head = new_employee; } else { Employee *p = head; while (p->next != NULL) { p = p->next; } p->next = new_employee; } printf("录入成功!\n"); } // 修改员工信息 void modify_employee() { char id[MAX_ID]; printf("请输入要修改的员工工号:"); scanf("%s", id); Employee *p = head; while (p != NULL) { if (strcmp(p->id, id) == 0) { printf("请输入员工姓名:"); scanf("%s", p->name); printf("请输入员工部门:"); scanf("%s", p->department); printf("请输入员工薪资:"); scanf("%f", &p->salary); printf("请输入员工考勤:"); scanf("%d", &p->attendance); printf("请输入员工绩效:"); scanf("%d", &p->performance); printf("修改成功!\n"); return; } p = p->next; } printf("该员工不存在!\n"); } // 删除员工信息 void delete_employee() { char id[MAX_ID]; printf("请输入要删除的员工工号:"); scanf("%s", id); Employee *p = head; Employee *prev = NULL; while (p != NULL) { if (strcmp(p->id, id) == 0) { if (prev == NULL) { head = p->next; } else { prev->next = p->next; } free(p); printf("删除成功!\n"); return; } prev = p; p = p->next; } printf("该员工不存在!\n"); } // 查询员工信息 void query_employee() { char id[MAX_ID]; printf("请输入要查询的员工工号:"); scanf("%s", id); Employee *p = head; while (p != NULL) { if (strcmp(p->id, id) == 0) { printf("姓名:%s\n", p->name); printf("工号:%s\n", p->id); printf("部门:%s\n", p->department); printf("薪资:%.2f\n", p->salary); printf("考勤:%d\n", p->attendance); printf("绩效:%d\n", p->performance); return; } p = p->next; } printf("该员工不存在!\n"); } // 打印员工信息 void print_employee() { Employee *p = head; printf("=====================================\n"); printf("= 员工信息 =\n"); printf("=====================================\n"); printf("姓名\t工号\t部门\t薪资\t考勤\t绩效\n"); while (p != NULL) { printf("%s\t%s\t%s\t%.2f\t%d\t%d\n", p->name, p->id, p->department, p->salary, p->attendance, p->performance); p = p->next; } } // 计算员工工资 void calculate_salary() { char id[MAX_ID]; printf("请输入要计算工资的员工工号:"); scanf("%s", id); Employee *p = head; while (p != NULL) { if (strcmp(p->id, id) == 0) { float salary = p->salary; // 计算津贴 if (strcmp(p->department, "技术部") == 0) { salary += 1000; } else if (strcmp(p->department, "市场部") == 0) { salary += 800; } else if (strcmp(p->department, "人事部") == 0) { salary += 500; } // 计算奖金 if (p->attendance >= 20) { salary += 1000; } if (p->performance >= 90) { salary += 1000; } printf("员工工资为:%.2f\n", salary); return; } p = p->next; } printf("该员工不存在!\n"); } // 考勤管理 void attendance_management() { char id[MAX_ID]; printf("请输入要管理考勤的员工工号:"); scanf("%s", id); Employee *p = head; while (p != NULL) { if (strcmp(p->id, id) == 0) { int attendance; printf("请输入考勤记录:"); scanf("%d", &attendance); p->attendance = attendance; printf("考勤管理成功!\n"); return; } p = p->next; } printf("该员工不存在!\n"); } // 绩效考核 void performance_assessment() { char id[MAX_ID]; printf("请输入要考核绩效的员工工号:"); scanf("%s", id); Employee *p = head; while (p != NULL) { if (strcmp(p->id, id) == 0) { int performance; printf("请输入绩效记录:"); scanf("%d", &performance); p->performance = performance; printf("绩效考核成功!\n"); return; } p = p->next; } printf("该员工不存在!\n"); } // 员工管理 void employee_management() { char id[MAX_ID]; printf("请输入要管理的员工工号:"); scanf("%s", id); Employee *p = head; while (p != NULL) { if (strcmp(p->id, id) == 0) { printf("请选择要进行的操作:\n"); printf("1. 晋升\n"); printf("2. 晋级\n"); printf("3. 调整\n"); printf("4. 离职\n"); printf("5. 退休\n"); int choice; scanf("%d", &choice); if (choice == 1) { printf("晋升成功!\n"); } else if (choice == 2) { printf("晋级成功!\n"); } else if (choice == 3) { printf("调整成功!\n"); } else if (choice == 4) { delete_employee(); } else if (choice == 5) { printf("退休成功!\n"); } else { printf("无效选项!\n"); } return; } p = p->next; } printf("该员工不存在!\n"); } // 保存员工信息到文件 void save_employee() { FILE *fp; if ((fp = fopen("employee.txt", "w")) == NULL) { printf("文件打开失败!\n"); return; } Employee *p = head; while (p != NULL) { fprintf(fp, "%s %s %s %.2f %d %d\n", p->name, p->id, p->department, p->salary, p->attendance, p->performance); p = p->next; } fclose(fp); printf("员工信息已保存到文件!\n"); } // 从文件中读取员工信息 void load_employee() { FILE *fp; if ((fp = fopen("employee.txt", "r")) == NULL) { printf("文件打开失败!\n"); return; } Employee *p = head; while (p != NULL) { Employee *temp = p->next; free(p); p = temp; } head = NULL; char name[MAX_NAME]; char id[MAX_ID]; char department[MAX_DEPARTMENT]; float salary; int attendance; int performance; while (fscanf(fp, "%s %s %s %f %d %d", name, id, department, &salary, &attendance, &performance) != EOF) { Employee *new_employee = (Employee *)malloc(sizeof(Employee)); strcpy(new_employee->name, name); strcpy(new_employee->id, id); strcpy(new_employee->department, department); new_employee->salary = salary; new_employee->attendance = attendance; new_employee->performance = performance; new_employee->next = NULL; if (head == NULL) { head = new_employee; } else { Employee *p = head; while (p->next != NULL) { p = p->next; } p->next = new_employee; } } fclose(fp); printf("员工信息已从文件中读取!\n"); } // 主函数 int main() { int choice; while (1) { print_menu(); printf("请选择要进行的操作:"); scanf("%d", &choice); switch (choice) { case 1: input_employee(); break; case 2: modify_employee(); break; case 3: delete_employee(); break; case 4: query_employee(); break; case 5: print_employee(); break; case 6: calculate_salary(); break; case 7: attendance_management(); break; case 8: performance_assessment(); break; case 9: employee_management(); break; case 10: save_employee(); break; case 11: load_employee(); break; case 0: printf("谢谢使用!\n"); return 0; default: printf("无效选项!\n"); break; } } return 0; } ``` 注意:该代码仅供参考,实际开发中需要根据具体情况进行修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值