读研的时候,有一次和同学一起上自习。我在学习,他也在学习。我想,大家每天都一起上课,记笔记,上自习,完成作业,智商也差不多,为何考试的时候有时候差距会很大呢?这个问题我直到今天也没有答案,这几天和朋友闲聊说到这个事情。他们有得说是智商有差距,有得说是学习的时候心不在焉——看着在学习,其实已神游大千世界。.....,不过,我自己从来没有下过类似的结论。我武断的猜测,这个问题应该是没有让人心服口服的答案。
从事软件开发行业后,发现要学的东西越来越多。尤其是近几年,发现未知的知识实在是太多。恐怕IT人活到老学到老的压力是绝无逃避的可能性了。那么,关于学习,我们需要注意什么呢?2015年google开发者社区一个集会上,我曾经分享过一些思考。4年过去了,又积累了不少经验教训(其实就是老了不少),现在想总结这些年的观察,做一个总结。我感觉可能需要至少两篇文章才能说完。一个是本篇的关于Android学习的三个终极问题,另外一个是对一专多能的思考。
去年我在周爱明老师的《大道至简》一书里看到对“反思”一词的定义,深有感触。书里说,反思,既不是设问,也不是反问,而是对一个问题的持续关注。这么来看,十余年来我对考试成绩好坏原因的思考就是一种反思。
在继续本文之前,我想说,我这个人讲不出什么大道理,能讲的东西都是自己想过、尝试过、甚至在周围朋友,同事身上一起试验过的。即使不能从中学到什么有价值的东西,但看到像我这样的一个圆脸中老秃胖其实一年也没多少天是无忧无虑得,你也可以开心一下了。
关于学习,我认为有三个终极问题:
这三个终极问题是:
很多时候,很多人并不会意识到学个知识还有什么三个终极问题。比如,周围人都学某某技术,所以我要学。或者,学某某技术有前途和钱途,那我也学。坦白来讲,我很羡慕这些人。在和平、稳定的年代,随大流是稳妥的选择。我很后悔读研的最后不该听了中科院某老师的授课。2007年,他“深度思考”了中国经济,得出了一个结论,说咱们的经济列车高速开了这么久了,肯定会下降的,然后房价会跌。所以,工作后的前3年我看着房价飞涨的时候依然坚信这个结论。幸好父母亲果断,举债买房。当时我加班夜里回来后听说自己背负了100多万的房贷还很不开心。没想再过几年我发现自己居然少背了几百万的房贷。 所以,要是你没有意识到有这三个问题,你是幸福和幸运的——如果环境没有发生变化,你也无须改变。
上面三个问题是我自己在学习问题上的反思——反思的潜意思是我也没有答案。我觉得也很少有人能给出明确的、普适的答案。我有一种强烈的预感,在关于学习的这三个终极问题上,每个人一定都是在自己的无人区里探索。
承认无人区的存在是有百利而无一害的。我以前每次换工作都要找机工的杨总编等朋友请教,但发现他们的意见总是不理想。终于有一天我明白了,原来我在自己的无人区中,里边只有我一个人。我的家人,朋友都不能真正理解我,他们解决不了我的困惑。 不过,当在无人区里挣扎的我知道还有那么多亲人、朋友是支持我的,勇气就会更足。坚信总会有一天,我会短暂得从无人区出来,然后再走入下一个更高级的,更有挑战的无人区。
对了,去年我才发现温伯格原来早在《技术领导之路》一书里就曾提到过类似的情况,那一章的中文名叫“领导的成长”。
接下来,我要把这几年从事Android开发相关工作中看到的东西结合自己的认识讲一讲。我觉得它们一定能帮助到在Android技术领域里谋生的一些兄弟姐妹们。
根据我的经历和认识,Android技术领域划分按从下到上可分为三个大的层次:
接下来,我会从知识范围和主要工作内容、学习路线以及需要注意培养的专业素养这三个方面来考察下上述三个Android技术领域。
Android底层开发涉及到的知识范围和主要工作内容如下:
从事底层开发的码农们叫BSP或驱动开发工程师。涉及的专业知识集中在Linux Kernel或驱动方面。
Linux Kernel是无数人为之倾倒的知识金矿。当年我也认认真真读过毛德操老师的《Linux内核情景分析》这样的源码分析书籍。这本书对我的影响非常深,以至于我策划的深入理解Android系列的几本书可看做是毛老师的手法在Android系统上的复制。
底层开发的工作内容主要是移植和Bug Fix。在某些公司的日常工作中,只要找到解决bug的patch,打上去就好了。为什么会这样?因为Kernel是一个比较稳定的软件。在这里,稳定压倒一切。当然,其中也有非常具有挑战性的工作,比如优化相关的工作等。
如果你想从事Android底层开发,下面是这个领域的学习路线:
在这个领域里工作,请牢记“吃亏是福”这句话。吃亏意味着积攒经验。这个领域里的经验是至关重要的。所以,我在下面的基本素养里还会提到它:
接着来看Android系统层开发。它涉及的知识范围和主要工作内容如下:
Android系统层开发的主要工作有因Android系统升级带来的移植工作、或者是诸如华米OV各家系统的产品特性(因为原生Android系统没有,所以需要自己开发)。
最后,随着除手机外的智能设备兴起(如智能POS、智能汽车),这些特定设备上也有许多在系统层需要开发的工作。
相比底层开发,系统层开发有更多的个性发挥空间。MIUI、EMUI、color OS等等就是系统层个性发挥的结果。简单点说,如果可以把从事底层开发的公司看做是硬件公司,那么从事系统层开发的就可以看做是软件公司了。
我这个说法肯定是不对的,但这里想说的是这两个领域的思维方式不太一样,因为要解决的问题也不一样。
Android系统层的学习路线如下:
从编程语言上来说,Android系统层有很大一部分是用Java开发的。另外还有一大部分是用Native(C/C++)语言开发的,
所以,要想在这个领域做到游刃有余,对Java和C++语言要了解。题外话,还没了解C++的同学可以直接上C++11。它和C++98/03不同(C++之父Bjarne Stroustrup甚至说过“C++11看起来像一门新的语言”)。
关于C++11的知识,我在CSDN博客上"C++11学习"一文(也是《深入理解Android JVM ART》一书的第五章,因为ART JVM几乎都是C++11写的)做过一个较为全面的介绍(地址在文后列出)。
Android系统层是相当吸引广大开发者的一个领域。比如很多知名Android技术公众号都会时不时讲一讲Handler的实现、UI绘制的流程、Binder的工作原理、消息传递机制等这样的知识。 这些内容早在《深入理解Android》系列的卷1、卷2和卷3都覆盖了。只不过时过境迁,年轻的人现在更适应新的传播方式。
除了这些通用知识,Android系统层还有相当一部分属于专业领域知识。比如,蓝牙、Wi-Fi、NFC、Telephoney(其中的双卡双待功能算是中国特色的功能)。如果你从事类似这样的专业领域的工作,请注意把精力放在专业知识本身,而不是Android里的代码。比如,Wi-Fi、NFC、GPS、蓝牙技术出现得远比Android早。它们各自有非常深厚的专业、理论知识。在Android中,你看到的相关代码无非是它们在特定系统上的实现罢了。你务必要先了解这些专业、理论知识,才能看懂Android上的代码实现。更未雨绸缪的说法是,如果将来没有Android系统的话,你一样可以靠着对专业理论知识的了解另起炉灶。
这也是我说“基于Android、高于Android”的意思。一个最近发生的例子是,有个帮我审稿JVM ART一书的审稿专家现在研究Flutter里的虚拟机。我相信他会比别人走得更快,更轻松一点。
Andriod系统层开发的基本素养:
系统层这几年发展也很快(想想Android的发版速度),靠个人力量来追踪这么一个复杂系统已经很困难了,需要大家一起来知识共享。
虽然很多公众号会写一些文章来介绍Android某个新系统的特点,但其实在设备厂商里是有不同的团队来跟踪新系统里不同模块的变化得。比如,除了Google I/O外,谷歌给设备厂商还组织了一个叫Android Bootcamp这样的类似培训一样的集会,里边会比较详细的、按功能、模块来介绍新系统的特点。不过,参加Bootcamp所获得的资料往往要保密。
接着来看最后一层——Android应用层开发的知识范围和主要工作内容:
应用层开发的特点就是知识点多、更新速度极快。相信大家都有感觉。针对这个层面的开发者,我想,就不要拘泥于什么门派了,需要什么就学什么(注意,不是有什么就学什么)。相比其它两个领域, 应用层开发是为业务需求服务的。所以,为了更好得服务业务需求,该学什么就学什么。比如,我最近的方向转到应用层开发了,但我所在行业的应用主要用H5+webview来承载业务逻辑,那么我就重点花时间学习了这块的内容。
我个人认为从事应用层开发同学的比例最大,也是最能体会“跟不上知识更新步伐”感受的人。这一领域中有没有什么基础关键技术?我多年观察下来觉得在应用层开发领域,多线程编程、网络编程、设计模式等几个是基础关键知识,无论如何要想办法抓在手里。
还有,软件开发的方法论、甚至产品开发、项目管理都是这个领域里需要了解的。
另外,在某股技术“风”起的时候,要判断下它是为了解决什么问题而产生的,你的业务需不需要这种技术?我对曾经一起干活的小伙伴们说过,宁愿你闲着没事干,也不要乱学,瞎学。在这个领域,功利、目的性强一点好。不要为了学习而学习,也不要为了KPI去github上重复造轮子。这也是该领域的基本素养。
前几年我一直在系统层和靠近底层的领域里搞事情,有时候也会做一些应用层的开发。近来我在转入应用层开发的时候,花了一些时间研究应用层开发和系统层开发的一些区别:
不知道你有没有这样的感觉。学习过程中,如果碰到一个问题,如果反反复复、长时间去思考它的话,总有一天会明白。这其中,有极少数的几次会让你有一种顿悟的感觉。到目前为止,我职业生涯里谈得上顿悟的时候应该不超过3次。
在《深入理解Android JVM ART》这本厚达1000页书籍写完后,我给自己说,绝不要再写这样需要“操刀自宫"才能练成的书了。我应该把复杂的知识用简单明白的方式表达出来,然后大家再结合自己的认知和经历去体会、去利用这些知识就行。
最后的最后,我期望的结果不是朋友们从我的书、文章、博客后学会了什么知识,干成了什么,而应该是说,神农,我可是踩在你的肩膀上得喔。
神农和朋友们的杂文集 长按识别二维码关注我们