论程序员的自学心态
最近半年因为项目清闲,做了很多自学计划,很多都是心血来潮,也并没有都坚持下来,比如学习C语言、学习Spring和web基础知识、学习操作系统等。在这个过程中,突然意识到“心态”是学习中一个很重要的部分。程序员大部分是独自学习的,很容易进入一个懒惰或焦虑的极端状态,当心态不稳定时,会发现时间眼睁睁地流过,而你却无法进步,这是一种很难受的状态。当心态健康时,不仅能保持稳定的学习速度,还能在学习中得到快乐,进入一个正向循环。
楼主是一个凡人,资质平庸,学习的目的无非是提高竞争力,使自己不至于某天沦为公司裁员的牺牲品。如果你有更清晰的梦想和目标,说明你比楼主层次高很多,欢迎来指点楼主。
为学而学是不行的
一开始学习时,楼主看了许多帖子,里面的Java大神们都在说:要提高技术,就要不停地看源码,甚至自己造轮子……年轻的楼主深受这种理论影响,不屑于搞业务而日日研究如HashMap源码这样枯燥的东西,甚至计划自己写一套collection framework,把大神们造过的轮子再造一遍,似乎只要写完这一套东西就能立地成佛,能搞定所有的业务和bug。
当我开始写HashMap的时候就发现,为了写而写是一种很蠢的行为。一个轮子内部的那些看似精巧繁杂的结构,存在的意义是为了让轮子更好更长久地运转,而不是工程师为了炫技而创造的。如果我们没有一个实用的目标,反而会浪费时间,迷失在一些看上去很神秘的细节中。其实,像HashMap这样的数据结构,只需了解它大致的工作原理就可以了,余下的代码细节可以在使用有疑惑或者出了问题时再去看。
再比如,楼主看面经中总是提到JVM调优,因此觉得这是Java程序员进阶所必备的知识,于是就买了书和教程去看,但是发现对于调优这个话题看书效率奇低,书上比较多的是一些描述性的内容,如JVM的内存分布和垃圾处理算法;还有一些实用性的内容,比如调优工具、调优案例。有些内容反复看了又看,回想起来脑子里却不剩什么,远没有看完一个算法后的那种条理清晰的感觉。而花在这个问题上的时间却远远超过看算法的时间。
这几个周,同事要做一个自动化测试工具,问大家有什么好的建议。楼主想到自己一直学调优而无所得,灵机一动,提议在工具中加入调优功能,得到了同事认可。同事给楼主大概介绍了一些调优思路,推荐了一些资料去看。楼主希望争取到这个亲自实现调优功能的机会,于是幻想自己即将面临各种性能问题,为了解决这些问题开始储备知识,然后惊异地发现学习有了层次,楼主不再死板地按章节看书了,可以自动地筛选出重要和不重要的内容,甚至可以在脑中形成清晰的脉络了!
所以计算机是一门实践科学这句话一定要深刻理解。因为偏实践,所以不可能当王语嫣,因为许多理论是从实践中来的,好比数学公理,只能从实践中得到感性认识,无法从其他的理论推测得来,也无法死记硬背。楼主是一个学院派的人,在这方面吃了不少苦。从中总结出的方法论是:
- 计算机科学的知识大多是偏实践的,学习这些知识不能只看理论,要依托于实践。实践和理论应该是两条互相缠绕的螺旋线,当实践无法继续进行时就去看理论,当理论看起来无法理解更深时就去实践。
- 实践最好是一个项目,但大多数情况要自己提需求,寻找实践方法。可以是个人项目,也可以是自己的各种小demo等等,形式不限,学到就行。
- 学习与任何事一样,都需要务实。技术只是人们为了解决问题而创造的,包括那些听起来很高大上的框架和名词。只要怀着负责任的信念去做事一定会接触到各种各样的问题,面临问题自然会去思考解决方法,在这个思考的过程中,你实际上就开始接触了设计模式、JVM原理、计算机组成、网络协议等等……所以,不可以鄙视平时在公司做的那些看似简单的业务。
持续输出
长时间的学习很容易懈怠,陷入一种被动接受知识的状态。另外,一个人的思想永远不可能顾全所有方面。
比如,楼主的朋友最近想学习Java,于是楼主自告奋勇,每天给他介绍二十分钟Java基础。当说到垃圾处理时,楼主自然地老生常谈:Java内存分为新生代和老年代,一般的GC只对新生代进行收集,而只有老年代也没有空间了才会进行Full GC……朋友眨着天真的眼睛问楼主:为什么要分两个区进行收集,而不是每次都对所有内存进行垃圾处理呢?楼主惊讶地发现自己答不出来,因为从未想过这个问题……
今天楼主复习时无意中发现,书里其实有介绍这么做的原因,即大部分对象都是朝生夕死的,按年龄分代并频繁地收集新生区比较贴合这个模型,这样既能照顾到常用的内存,也能保证垃圾处理能在比较短的时间内结束。这一段楼主其实看过多遍了,但竟然从未将两者联系起来,也未思考过分区设计的原因……
又比如,有一次面试时面试官问Java线程池中核心线程数和最大线程数的区别。楼主轻车熟路地说:核心线程数是线程池的初始线程数,最大线程数是线程池能扩展到的最大线程数,只有任务队列提交满时才会扩容。面试官接着问道:“那你想过为什么要这么设计吗?”楼主支吾半天也没答上来……事后一想,其实很简单,就是为了既能重用线程,减少线程开销,又能满足偶尔的大规模请求而已。这么简单,为何当时没想到呢?
……因为平时看书的时候就缺乏思考啊……
对于楼主这种口号上的巨人、思考上的矮子,除了经常给别人讲东西从而被别人挑战之外,还有一个好办法,就是坚持写博客。
博客是一篇文章,需要有文章结构这种东西,为了使你的博客显得比较有逻辑性,你会被逼着去梳理知识点之间的逻辑,以及一门技术的由来、历史、产生背景等等。在梳理过程中,你会发现看书时遗漏的点被填满了。另外,把思路写出来能进一步强化你对知识的印象。而且,持续写博客会给你的学习造成一种健康的仪式感,即使一开始没有太多读者,你也会爱上这种输出的感觉,反过来督促自己为了写出更多博客而坚持学习。
行动紧张,但心情轻松
焦虑是自学最大的敌人。有一阵子看到朋友看书很快,自己也想加快脚步,可是却打乱了自己的一贯节奏。又有一阵子,像着了魔一样四处搜寻名人自传、大神博客,然后发现自己跟大神的差距要以数十年计,陷入一种无止境的焦虑。
楼主愿意相信,焦虑并不是完全不好的状态,因为它证明一个人想要进步,想跟那些优秀的人比肩。但是,“认识自己”也是一门非常重要的学问。每个人都是不同的,现在跟大神差距很大并不意味着几年后还会差距很大;但是有一个坚持下去的秘笈,跟跑马拉松一样,就是不要看别人,不要看终点。要做到这一点,先要接受自己的平凡,这样才能平心静气地去吸收知识、抵御外界的影响,而持续的焦虑只能适得其反。
如果每天都抱着一个远大的梦想,正襟危坐地努力学习,会发现很快就累了。之所以看电视剧不容易累,是因为潜意识就告诉自己在玩。如果学习的时候,也可以调整到一个好玩的心态,把问题当作小乐趣去解,会发现不知不觉就沉浸在解题的乐趣中,而感受不到时间的流逝,这种状态是学习的上乘状态。