程序员如何把控自己的职业
这篇文章的主要内容主要是我今年3月份在腾讯做的直播,主要是想让一些技术人员对世界有一个大体的认识,并且在这个认识下能够有一个好的方法成就自己。而不是在一脸蒙圈的状态下随波逐流,而日益迷茫和焦虑。直播完后,腾讯方面把我的直播形成文字的形式发了出来,我觉得我可以再做一个精编版。所以,有了这篇文章,希望对大家有帮助。
对我来说,在我二十多年的工作经历来看,期间经历了很多技术的更新换代,整个技术模式、业务模式也是一直变来变去,我们这群老程序员成长中所经历的技术比今天的程序员玩的还更杂更多。我罗列一下我学过的,而且还被淘汰掉的技术,大家先感受一下。
- MIS应用开发:FoxPro,PowerBuilder,Delphi - OA:Lotus Notes,VBScripts - 微软:ODBC/ADO,COM/DCOM,MFC/ATL,J++ - 服务器:AIX,HP-UX,SCO Unix - Web:CGI,ISAPI,SOAP - RPC:CICS,Tuxedo - J2EE:Websphere,Weblogic - DB:Sybase,Informix
我想说的是,无论过去还是今天,我们这些前浪和你们后浪所面对的技术的挑战和对技术的焦虑感是相似的,我们那个时候不但玩996,还玩封闭开发(就是一周只能回家一天)。当然,唯一好的东西,就是比起今天的程序员来说,我们那个年代没有像微信、微博、知乎,抖音这些巨大消耗你人生的东西,所以,我们的工作、生活和成长都有很效率,不会被打断、喜欢看书、Google还没有被封……当然,那时代没有StackOverlow和Github这样的东西,所以,能完成的东西或质量都一般。
当然,这里并不是想做一个比较,只是想让大家了解一下两代程序员间的一些问题各有千秋,大同小异。在整个成长过程中,其实有很多东西是相通的,其本上来说,就是下面的三件事——
第一,如果想要把控技术,应对这个世界的一些变化,需要大致知道这个世界的一些规律和发展趋势,另外还得认识自己,自己到底适合做什么?在这个趋势和规律下属于自己的发挥领域到底是什么?这是我们每个人都需要了解的。
第二,打牢基础,以不变应万变,不管世界怎样变化,我都能很快适应它。基础的重要程度对于你能够飞多高是相当有影响的,懂原理的人比不懂原理的人能做出来的事情或是能解决的问题完全是两个层级的。
第三,提升成长的效率,因为现在社会的节奏实在太快了,比二十年前快得太多,技术层出不穷,所以我们的成长也要更有效率。效率并不单指的快,效率是怎么样更有效,是有用功除以总功(参看《加班与效率》),怎么学到更有效的东西,或者怎么更有效学习,是我们需要掌握的另一关键。
下面是我这多年来的一些认识,希望对你有帮助。
目录
世界发展趋势
我个人经历的信息化革命应该分成三个阶段:
- 1990年代到2000年,这个时代MB时代,是雅虎、新浪、搜狐、网易门户网站的时代,这个时代就是ISP/ICP互联网提供商,把一些资讯数字化,然后发布到网络上。
- 2000年到2010年,这个时代叫GB时代,或是叫多媒体或UGC时代,上网开始变得普遍了,每个人手里的数码设备开始变得多了起来,可以上传照片,可以上传视频,甚至可以在网上做社交。
- 2010年到2020年,这个时代叫TB时代,这过去的十年是移动互联网时代,移动互联网只需要手机在线,不需要依靠电脑。因为手机随时在线,所以个人的各种各样的数据始终在被收集,只要用户上网就会产生数据,所以人的行为最终也被数字化了。
所有的硬件和软件都是跟着需要处理的数据而演进的,我们需要更大的带宽,更大的硬盘,更多的处理器……大到一定时候就只能进入分布式化的技术架构了,再大,数据中心也顶不住了,就会要引入更为分布式的边缘计算了。
另一方面,从业务上来看,我们可以看到整个世界就在不断地进行数字化,因为,只要数字化了,就可以进行复制传播和计算,只要可以进行计算了,就可以进行数学建模,就可以自动化,只要可以自动化了就可以规模化,只要可能规模化了,就可以改变整个行业。人类的近代史的大趋势基本上都是在解决能源和自动化的事,源源不断的能源是让机器不知疲倦的前提条件,用机器代替牲口,代替人类进行工作是规模化的前提条件。
所以,技术的演进规律基本是自动化加规模化,从而降低成本,提升效率。这就是为什么世界变得越来越快,人类都快跟不上节奏的原因,主要是整个社会不断被机器、数据所驱动。
人才需求
在这个过程中,需要什么样的人?下面是我的一些认识——
- 技工,在机器和自动化面前,肯定是需要能够操作机器的技术工人了,这类人是有技术的劳动力。在编程的圈子里俗称“码农”,他们并不是真正的工程师,他们只是电脑程序的操作员,所以,随着技术门槛的下降或是技术形式的变更他可能就会变得越来越不值钱,直到被淘汰掉。
- 特种工,这种人是必须了解原理和解决难题的一类人,他们是解决比较难的、特定的一些技术问题。当一种技术被淘汰,他并不容易被淘汰,因为他懂原理,原理就是解决问题的能力,是解决问题的套路和方法。
- 工程师,不但是使用技术,还可以把活儿做好,他们认为代码更多的时间是在维护,这些人使用各种各样的手段和各种技术,精益求精地持续不断地提高代码的易读性、扩展性、可维护性和重用性,这个过程似乎永无止境。对于这些有“洁癖”,有“工匠精神”,有“修养”的技术人员,我们称他们为工程师。这种人做事又稳又快,而且可以做出很多称手的工具和方法论。
- 再往上是设计师和架构人员,这些人主要是开发一些工具,框架,模式,提升软件开发和维护效率,同时也提升用户体验,和提升稳定性、性能、代码重用等,总的来说就是为了降本增效。这类人的工作降低了技术得到门槛,他们把技术门槛降低了以后,就可以把这个技术普及开来,就可以由广大劳工、技工、特殊工人使用了。
- 还有一类人是经理,经理主要是组织团队、完成项目、创造利润。这类人中,即有身先士卒的leader,也有高高在上的boss,但无论怎么样,这些人只不过是为了让一个公司或是一个团队更好组织在一起的“粘合剂”,这类人只有在大公司中才会变成更有价值。
这就是我总结的世界需要哪些人才,我们了解这些东西以后大概就明白我们现在所处的位置有什么样的问题,我们应该去什么样的地方。
Google评分卡
接下来,我们再来看看Google的SRE的自我评分卡:
0 – 对于相关的技术领域还不熟悉
1 – 可以读懂这个领域的基础知识
2 – 可以实现一些小的改动,清楚基本的原理,并能够在简单的指导下自己找到更多的细节。3 – 基本精通这个技术领域,完全不需要别人的帮助
4 – 对这个技术领域非常的熟悉和舒适,可以应对和完成所有的日常工作。
- 对于软件领域 – 有能力开发中等规模的程序,能够熟练和掌握并使用所有的语言特性,而不是需要翻书,并且能够找到所有的冷知识。
- 对于系统领域 – 掌握网络和系统管理的很多基础知识,并能够掌握一些内核知识以运维一个小型的网络系统,包括恢复、调试和能解决一些不常见的故障。
5 – 对于该技术领域有非常底层的了解和深入的技能。
6 – 能够从零开发大规模的程序和系统,掌握底层和内在原理,能够设计和部署大规模的分布式系统架构
7 – 理解并能利用高级技术,以及相关的内在原理,并可以从根本上自动化大量的系统管理和运维工作。
8 – 对于一些边角和晦涩的技术、协议和系统工作原理有很深入的理解和经验。能够设计,部署并负责非常关键以及规模很大的基础设施,并能够构建相应的自动化设施9 – 能够在该技术领域出一本经典的书。并和标准委员会的人一起工作制定相关的技术标准和方法。
10 – 在该领域写过一本书,被业内尊为专家,并是该技术的发明人。
SRE需要自评如下这些技术或技能。
– TCP/IP Networking (OSI stack, DNS etc)
– Unix/Linux internals
– Unix/Linux Systems administration
– Algorithms and Data Structures
– C/C++
– Python
– Java
– Perl
– Go
– Shell Scripting (sh, Bash, ksh, csh)
– SQL and/or Database Admin
– Scripting language of your choice (not already mentioned) _____________
– People Management
– Project Management
这个评分卡是面试Google前需要候选人对自己的各种技术进行自评,也算是一种技术人员的等级的度量尺,其把技术的能分成11个等级,我用颜色把其它成四大层级,希望这个评份卡能够给你一个能力提升的参考标准。
认识自己
认识了世界是怎么发展的,也知道技术人员的种类和层级,那么还要了解一下自己,因为如果不了解自己,那么你也无法找到自己的路和适合自己的地方。
我觉得,一个人要认识自己就需要认识自己的特长、兴趣、热情、擅长等,下面是一个认识自己的标准方法:
- 特长。首先你要找得到自己特长。你要认识自己的特长,找到自己的天赋,找到你在DNA里比别人强的东西,就拿你的DNA跟别人竞争就好了。所以你要找到自己可以干成的事,找到别人找你请教的事,你身边人找你请教就是说明你有特长。这是找到自己特长非常非常重要,扬长避短。
- 兴趣。如果你没有找到自己特长,就找自己有兴趣有热情的东西。什么叫兴趣?兴趣是再难再累都不会放弃的事。如果你遇到困难就会放弃不叫兴趣,那叫叶公好龙。不怕困难,痴迷其中,就算你没有特长,有了这种特质,你也是头部的人才。
- 方法。如果你没有特长,没有兴趣和热情就要学方法。这种方法就是要有时间观念,要会做计划,要懂统筹、规划对于做过的事情,犯过的错误多总结,举一反三,喜欢自己找答案,自己探究因果关系,这是一些方法,自己总结一些套路。
- 勤奋。如果你没有特长,没有兴趣,也没有方法,你还能做的事就是勤奋,勤奋注定会让你成为一个比较劳累的人,也是很有可能被淘汰的人随着你的年纪越来越大,你的勤奋也会越来越不值钱。因为年轻人会比你更勤奋,比你更勤奋、比你斗志更强,比你能力更强,比你要钱更少的人会出现。勤奋最不值钱,但是只要你勤奋至少能够自食其力。
以上就是为了应对未来技术变化,作为个人必须要从特长、兴趣、方法一层一层筛选挖掘,如果没有这些你就要努力和勤奋。就只能接受“福报”了。
从我个人而言,我不算是特别聪明的人,但自认为对技术还是比较感兴趣的,难的我不怕。有很多比较难啃的技术,聪明点的人啃一个月就懂了,我不行,我可能啃半年。但是没有关系,知识都是死的,只要不怕困难总有一天会懂的。最可怕是畏难,为自己找借口,这样就不太好了。
打好基础
最前面提到我学的各式各样的被淘汰的技术,会让你感觉很迷茫,或是迷失。但前面也提到了“谷歌评分卡”,在这个评分卡中,我们看到了许多基础原理方面的内容,其实要应对未来的变化,很重要的一点就是无招胜有招,以不变应万变。
变化都是表面的东西,内在的东西其实并没有太多的变化。理论层面上变得不多,反而形式上的东西今天一个花样,明天一个花样,所以如果要去应对这种变化,就一定要打牢自己的基础,提升内功修养。比如像编程的一些方式和套路,修饰模式原理本质,解耦,提升代码的重用度等。提升代码重用度必须解耦,要跟现实解耦,提升抽象,这些都是一些技术基础。无论用什么语言,都是这么做的。
打牢基础就可以突破瓶颈,不打牢基础没有办法突破瓶颈。在技术世界不要觉得量变会造成质变,这是不可能的。技术这个东西就像搞建筑砌砖头,砌砖头砌的再多也不可能让你能成为一个架构师的,因为你不懂原理,不懂科学方法,你就不可能成长上去的,就像学数学一样,当你掌握了微积分这种大杀器后,你解题的能力是无所披靡,而微积分这种方式绝对不是你能“量变”出来的。
所以你必须学习基础的理论知识,如果不学这些基础理论知识,还要学习解题思路和方法,如果你只学在表面,那么当这个技术的形式有变化,就会发现以前学的都没用了,要重头学一遍。掌握技术基础可以让自己找到答案和知识,基础是抽象和归纳,很容易形成进一步的推论。我们学的很多技术实现都逃不脱基础原理,不管是Java,还是其他语言,只要用TCP用的都是相同的原理,逃不出范围,只要抓住原理,举一反三,时间一长了,甚至还可以自己推导答案。对于技术的基础,我会把其它成四类:
- 程序语言:语言的原理,类库的实现,编程技术(并发、异步等),编程范式,设计模式……
- 系统原理:计算机系统,操作系统,网络协议,数据库原理……
- 中间件:消息队列,缓存系统,网关代理,调度系统 ……
- 理论知识:算法和数据结构,数据库范式,网络七层模型,分布式系统……
这些知识其实就是一个计算机科学专业的学生他所要学习的原理,但可惜的是,我们的一些学校教得也很糟糕,不但老师能力不足,而且放着世界上最优秀的教课书不用了,一定要自己写一本。讲也讲不全,还有各种错误,哎……总之,如果你学习用用到的教材不行,那么可以肯定的是你的学习效率一定是很糟糕的。这就是为什么我们大学上完了,还是跟个傻瓜一样,还要在工作中再重新自学。
不过,就算自学,这些基础技术大概需要四五年的时间堆叠。我工作二十年了,这二十年来基本还是这些原理没变,无论形式怎么变,但是核心永远还是这些,理论创新很难,这是以不变应万变。
学习效率
谈到学习效率,就需要拿出这张学习金字塔的图来了。从图可以看到学习方法分布两层,一种是被动学习,也是浅度学习,听讲,阅读,视听,演示都是在被动学习,而与人讨论,自己动手实践,教授给别人是主动学习。主动学习我们称之为深度学习,如果你不能深度学习,你就不能真正学到东西。这也是你会经常有“学那么多干什么,不用就忘了”,这就是浅度学习的症状了。
下面,我给出一些我自己觉得不错的学习经验:
1、挑选一手知识和信息源。对于学习方法:第一我们一定要到知识源去挑选知识,知识信息源非常关键,二手信息丢失太大了,谭浩强写的书就丢失太多信息了。目前计算机一手知识基本都是国外的,所以英文非常重要。我鼓励大家一定读第一手的资料。如果你英语有问题,至少要看翻译过来,最好是原汁原味翻译的,不要我理解了给你讲那种,那种也是被别人嚼一遍再讲给你你没有体会,是别人带着你,别人的体会会影响你,也许你的体会会比他更好,因为是你自己总结出来的东西,所以知识源很重要。
2、注意原理和基础第二要注重基础原理。虽然可以忘记这个技术,但是原理记在心里,我可以徒手实现出来,而且通过原理可以更快学习其他类似的技术。所以原理很重要!当你学会C、C++要学Java和GO都很快。
3、使用知识图谱一定要学会使用知识图,把知识结构化。从一个技术关键点开始不断地关联和细化下去,比如:关于TCP协议,首先第一个要记住状态图,怎么建立连接,怎么断连接,状态怎么变迁。TCP没有连接,是靠状态维护连接的。其次,要了解TCP怎么保证可靠性,就是丢包以后怎么重传,重传有哪些技术点。然后,重传会让你联想到拥塞控制,拥塞控制到滑动窗口……。这基本就是TCP的所有东西了,找到关键点,然后顺着这个脉络一点点往下想,通过知识图关联就可以进行顺藤摸瓜。我们不需要记所有知识,那些手册的知识不需要记,你知道在哪里能找到就可以了。你脑子里面要有地图,学一个东西就跟在城市生活一样,闭上眼睛就知道地图,A点到B点怎么去大概方向要知道。我在北京我去广州,广州在南边,我大概坐飞机还是火车要心里有数。。
4、学会举一反三。就是用不同方法学一个东西,比如说学TCP协议,看书是一种方法,编程是另外一种方法,还有用做Debug去看的,用不同方法学一个东西会让你更加熟悉,你学一个知识的同时把周边也学了。比如说学前端能不能把HTTP学一下,比如说长连接、短连接,包括hp1、hp2有一些不一样的东西。
5、总结和归纳。只有学会总结和归纳,才能形成自己的思维框架、自己的套路、自己的方法论,以后学这个东西应该怎么学。就像学一门新的语言,不管GO语言,还是Rust语言,第一件事情就是了解内存是怎么管理的,数据类型什么样,第二是泛型怎么搞,第三是并发怎么弄。还有一些抽象怎么弄,比如说怎么解耦,怎么实现多态?套路这种东西只有学的多了以后才能形成套路,如果你只学会一门语言不会有套路,你要每年学门语言,不用学多精,你思考这个语言有什么不一样,为什么这个这种有玩法,那个有那种玩法,这些东西思考多了套路方法论就出来了。比如说Windows和Linux有什么不同,Linux和Unix又有什么不同?只有总结自己的框架、套路和方法,这些才永远不会被淘汰。
6、实践和坚持。剩下就是多做多练,多坚持,只有实践才会有经验,只有锻炼了才能够把自己的脂肪变没,所以,要把知识变成技能必须练,就像小学生学会加减乘除,还是要演练,必须多做题,题目做得多了,自然掌握得好。要挑选好的知识源,注重原理技术,有一些原理的基础的书太枯燥,但是我告诉你学习这些基础太值得投入时间,搬砖赚几十元不值得,因为赚的是辛苦钱,老了就赚不了,必须要赚更有能力的钱,这是学习投资。
小结
好了,该到这篇文章收尾的时候了,小结一下,如果你想更好的把握时代,提升自己,你需要知道这个时代的趋势是什么,需要什么样的人,这些人需要什么样的能力,这些能力是怎么获得的,投入到基础知识的学习就像“基建”一样,如果基础不好,不能长高,学习能力也是需要适应这个快速时代的重要的基础能力,没有好的学习能力,很快就会掉队被淘汰。
这些东西,是我从业二十年来的总结和体会,希望对你有用。
(全文完)
(转载本站文章请注明作者和出处 酷 壳 – CoolShell ,请勿用于任何商业用途)
《程序员如何把控自己的职业》的相关评论
我觉得视听和演示的学习留存率没有阅读高
我觉得吸收知识最终就是将知识“形象化”,视听和演示可以更好的辅助知识形象化。而对于新知识,阅读很难起到这个作用,但是阅读可以让你更加的把握知识的细节。两个行为如果排个序:视听先于阅读之前完成。
我觉得视听的学习效率不如阅读,主要是因为阅读可以一目十行,而视听只能按顺序。
“数据为” -> “数据库” 勘误。
认识自己 一小节中『特长』二字没有加粗
腾讯方面这我的直播形成文字的形式发出来
耗子叔这句读起来好像缺字。
皓哥总是这么真诚,不藏私,总是不厌其烦地告诉你他相信的道理,每次看皓哥的文章都能缓解焦虑。
要是你看见基础知识要学四五年就开始焦虑了,那就是你的事儿了……
四五年就焦虑?我学基础知识学了十多年。
有些基础看书看不懂咋办😂
基础其实是理论,对于理论的处理实际上是一个螺旋上升的过程,不必纠结当下的不懂。随着你实践越多,真正懂的也越多,加上文中所说的经常思考和总结,基础自然懂得越来越多。
谢谢您
建议作者加个点赞的按钮. 这是用户需求!
砍掉需求,哈哈哈
学习效率中有听讲, 阅读. 那么视听的作用时看视频么? 应该是. 建议大家多评论, 可能开始评论的时候, 疑惑的答案就自己跳出来了.
有一种四维空间看下来的视角,学习了
“提升内功休养” → “修养”
刚工作,已经逐渐体会到上学时学的基础理论带来的优势了,庆幸三年前开始在CoolShell看耗子叔的文章
之前所有的枯燥都是值得的
找到一个错别字,认识自己标题下第一句,“知识”->“认识”
前浪、后浪顺序发了,你是前浪。哈哈
勘误:如果不基础不好 –> 如果基础不好
每个字都认真读了,又学到很多,谢谢博主。
确实是太难了,不停的开始,结束,开始,结束
勘误:工匠精精 -> 工匠精神
前辈说的太对了,理论知识是根,应用层技术是枝叶,如果不懂得理论知识及原理,当应用层的哪些枝叶枯萎淘汰之后,根是依然存在的,它又会萌生出许多新的枝叶及应用层技术,当我们掌握了根及理论基础知识,再去学习新的应用层技术我们将学习的更快,更能抓住本质,毕竟枝叶里面流淌的是根带给他们的水源。三非二本大三学子向前辈致敬,目前在边学java后端(先活下去),边学习计算机理论基础(其实学校讲了,不过就像前辈说的,唉……,自己买了一些书慢慢啃,有的书感觉还不错),慢慢学习叭,就像前辈说的,我也是有点兴趣,也不聪明,但是好在还蛮坚持的,慢慢来叭!
网络七屋模型
为什么这个这种有玩法
我这个后浪,也玩过WebSphere和weblogic哈哈
有脑子的练才会有技能和经验
讲得很好,尤其是特长》兴趣》方法》勤奋这个由上而下的链。中国的教育就是完全抛弃上层路线,只保证下限,就是你是否勤奋。导致中国人虽然很多人能“走向小康”,但大多数人被剥夺个性和特长,沦为高效率的工作机器。
本人学习编程一年,想多看看大拿们写的代码。 希望皓哥或网友们能分享一些您们经常浏览的网站。
github呀
学习一个东西,不能留存于表面,要学懂里面的道理,技巧只是道理的一个表现。技近乎道
这些方法不仅仅适用于程序员这个职业,其他行业也是相通的。
写得好,以后想邀请皓哥给我们【技术人成长】社区分享干货,现在我们先努力达到有邀请的资格。
赞
感谢皓哥的分享。确实基础才是最重要的,各种框架都是形式的变化。向皓哥学习
深表同感,如今国内同行在技术输出方面也有一些新的问题,在看了不少内行写的相关技术文章、博客时,有部分作者会不自觉的把一些显而易见的东西忽略掉,但是往往知识的连贯性就是要用这些显而易见的东西所连接起来的,所以阅读技术源文献确实很重要
举例子说,基础知识是内功心法,本来也有理解门槛。但不至于完全找不到入门方式。
英语真的非常重要,非常重要,非常重要。
重点的技术更新换代,或者一些新思想的诞生全是英语资料,有些甚至一两年后都没有翻译。
我是erpadmin,我比较关注投入产出比,像贝佐斯那样写代码配置资源,规划资源,整合资源的人
关于如何学习,推荐看看《刻意练习》这本书
感谢你的分享,了解和学习到很多基础知识
静悄悄的来
耗子哥狂打错别字的习惯还真是一直没变啊,哈哈
比如:
理论知识:算法和数据结构,数据库范式,网络七屋模型,分布式系统……
感谢楼主的分享,自考本科计算机学院路过
写的很赞,很感激楼主的无私分享!不过针对上述的一些技术书籍或知识体系,有没有可推荐的书籍或是网站,在今天信息大爆炸的年代里,更多的时候,资料很零散化,不说别的,找资料成本很高,且书的质量也没法保证,这点挺让人头大的。大学我们学的C语言就是谭浩强版的,从未想挑战权威,看到楼主的评论,才发现构建知识体系,最大的拦路虎是,自己盲从,缺乏思考力。希望楼主能帮忙解惑,谢谢啦
有的时候迷茫了,就回来看看耗子叔的文章
「世界变得越来越快,人类都快跟不上节奏的原因,主要是整个社会不断被机器、数据所驱动」 耗子叔的观点真是非常深刻!
打好基础,培养良好的思考和实践方式,保持对技术的热情和敏感才是能够保持持续竞争力的根本保障。特别是在当下,兜售的焦虑无处不在,更要保持清醒的认识。
赞同
每次迷茫就多看看耗子叔的博客,很多理论都只是认识,编程之路任重而道远
挺好,挺有启发的
谢谢您的分享!
自己常常犯的错误就是战术上勤奋,但是战略上懒惰。每天花了大量的时间在重复的工作上,工作了四年成为了熟练工,但是心里知道并没有本质上的提高。将来应该多下功夫在理解原理上。
希望将来能看到管理方面的经验分享。
大佬啊,学到了,很有帮助~
受益了
感谢耗叔的分享,很真实很受用!
皓哥,勘误:
【这类人的工作降低了技术得到门槛】得到->的
30出头,冥茫,又不勤奋,从此刻开始有计划的学习
无论多么迷茫,只要看了浩叔的博客,瞬间就会变得清醒,心静如水,安排计划,一路向前
很感谢博主的分享,看了之后挺有收货的,在迷茫中指明道路。感谢!