什么源码

源代码(也称源程序)是指未编译的按照一定的程序设计语言规范书写的文本文件,是一系列人类可读的计算机语言指令。 在现代程序语言中,源代码可以是以书籍或者磁带的形式出现,但最为常用的格式是文本文件,这种典型格式的目的是为了编译出计算机程序。计算机源代码的最终目的是将人类可读的文本翻译成为计算机可以执行的二进制指令,这种过程叫做编译,通过编译器完成。

前言

我有一个大学同学,我们俩合作过很多项目。只要有他在,我就特别放心,因为几乎所有难搞的问题,到他这,都能够巧妙地化解。他给我印象最深刻的一句话就是,“有啥解决不了的?只要你肯阅读源码。”

什么人适合阅读源码?

说起来源码,我是不太建议新手去阅读,容易劝退。不信,你让一个小学生去读一下《百年孤独》,我保证他会从此对阅读失去兴趣。去年,我忍着头皮读了这本书的前十页,然后就没有然后了——读不下去。我觉得自己还是嫩了点,生活阅历没到那个层次,感悟、内化、思考的能力也没到那个份上。

考核

我建议程序员至少在有一到两年编程经验后,再去阅读源码,这个时间段会比较合适。我是大三出去实习的,那会的水平真不敢恭维。不过,公司对我们的耐心还是有的。二十多名新人,分两组,一组做个计算器,一组做画图工具,要求两个月内完成。

说白了,就是考核我们的,不合格就请退。我做的是计算器,成品后来放到了 CSDN 的资源库上,骗了不少 C 币。坦白说吧,有一部分代码我是从网上复制粘贴的。

就这部分代码,我研究了一个多月时间,硬是没有吃透,只是说把其中的一些小 bug 修复了——靠着这种能力,我谋得了一份可以挣钱养活自己的差事。

接下来一年半的工作时间里,我没有强逼自己去阅读源码,而是跟着项目组的进度,不断地积攒编程的经验。就像小孩子一样,在会跑之前,总得先学会走路啊。

Flex源码阅读

时间来到了 2012 年,我通过某些契机了解到公司以后的发展重心会是 Flex(结合了 B/S 与 C/S 技术优点的新一代富客户端技术),我就开始在项目间隙研究起了 Flex 的源码。这时候,我觉得自己“复制粘贴”(或者说面向搜索引擎)的能力已经炉火纯青了,平常的工作任务都能够应付,但总觉得自己还很菜。

Flex 的整体框架是日方人员设计的,在原生的技术上做了一层封装,组件更丰富了,有点类似于现在前端非常火热的 Vue.js 或者 React。

我当时还没有参与到 Flex 的项目当中,但因为和公司的一个前辈关系比较要好,就找他要了一个小项目的源码,在本地搭了一个调试环境,开始“打怪升级”了。

不得不承认,日方开发人员写的代码还是非常严谨的,注释比代码多得多。我的日语水平虽然不咋滴,但在翻译软件的帮助下,再加上对代码的感知能力,还是能够钻研下去的。

这里顺带透露一点。有两个源码的作者来过苏州的分公司,我见过他们,年纪至少在四十岁以上,据同事说,有一个都五十多岁了,看来保养的不错啊。他们为人非常谦和(学到了我们民族的精髓),完完全全是一副纯粹的技术人的模样——那些大龄程序员都去哪了?答案就在这里,只要你技术够牛,公司就需要你。

能力提升+涨薪

经过四个多月不懈的努力,我觉得自己的编程能力得到了飞速的提升,不仅会用框架已有的组件,在必要的时候还能够扩展一些自定义的组件——因为我已经读懂了大部分的源码,敢在上面动手动脚了。

在这期间,我用 Flex 做了一款聊天工具,我在很早之前的文章里提到过。公司内部使用的 spark 聊天工具是有档案记录的,不能在上面谈一些工作之外的话题,比如说有几个同事喜欢分享魔兽世界的心得体会,我这个工具恰好为他们提供了便利,服务器就在我本地电脑上。

就是凭借这款聊天工具,我被一个领导看中了,直接挖我过去做了小组长,负责项目的编码部分。更重要的是,加薪了!

所以说,我一直觉得,阅读源码是一项重要的能力——它能够让你从一名代码的搬砖工人蜕变成为一名会造轮子的工程师。

找工作遇阻(不是我)

我现在八年工作经验了,但前几年出来的时候没注重基础,没研究过源码,现在三十了,感觉压力上来了。投了很多简历,也没啥面试的消息。

上面这段话是前天一名读者安少给我发的信息,看完后,真的蛮为他感到惋惜的。阅读源码虽然不是万能的,但对一个程序员的能力提升,真的是非常重要,大概就相当于内功心法吧。

如果安少在程序生涯的早期(三五年的时候)就能够静下心去源码里“潜水”或者“畅游”一段时间,他就不至于在 30 岁的时候担心自己的前途。

参加过 Java 岗位面试的读者应该清楚,面试官喜欢问一些关于源码方面的知识点,比如说,“HashMap 的底层原理是什么?大小超过了负载因子定义的容量该怎么办?”如果平常肯去倒腾源码的话,这些问题你肯定能够答得行云流水,否则真的是一脸懵逼啊。

最后

总结一下,阅读源码不仅能够提升你的编程能力,还能够让你从容面对面试官的提问。对了,我差点忘记一点,阅读源码还是解决 bug 的银弹

这也是为什么 GitHub 这么流行的原因之一啊,因为它上面的源码都是开源的。这就意味着,如果程序出现了故障,而故障的原因是由这些源码引起的,你就不必苦苦等待源码的作者去修复它,“自己动手丰衣足食”啊。毕竟源码的作者还有很多其他重要的事情要做,他不可能在线等你 issue 啊。

还记得我在文章开头提到的大学同学吧,他遇到问题的第一反应就是去把源码的底裤扒个精光。在他眼里,问题发生的根源要么是他自己,要么就是源码,所以我一直觉得他蛮有极客精神的。

而我,通常是,先检查自己的代码,如果找不出,去求助一下搜索引擎,如果还找不出,才会去阅读源码。

不要怕,一开始阅读源码真的会有点难度,但如果你想要成长,就不能一直待在自己的舒适区,你得硬着头皮上。等你头硬(秃)了之后,就真的变强了!

 

最后的最后

对于上面读者的问题,我的回答是:深入底层,坚持学习!在35岁之前还有很大的提升空间,35也算是一道坎,主要是企业对这个年龄段的人要求会更高,一般还需要一定的管理能力,所以在提升技术的同时,能拿下MBA就更好了

想要不被淘汰,没有中年危机很简单、也很难:坚持学习,达到这个年纪的人应该达到的水平即可

好了就说这么多吧!什么?还有我分享些资料?不知道该从哪里学?不知道该怎么学?

 

1、阅读源码

阅读、分析源码是程序员最基本的码代码能力也是码农的根本所在,学习经典源码中所用到的经典设计思想及常用设计模式,能够帮你了解大牛是如何写代码的,从而吸收大牛的代码功力。在阿里面试中,MyBatis,Spring等框架的底层原理是经常会被问到的。

2、分布式架构

阿里巴巴有很多大团队,这种大团队里有很多小团队,到小团队之后,做的业务都不相同,如果想立足成为一线互联网公司中的万能选手,最主流的分布式架构中有很多知识都是必须要去了解与学习的。并且在阿里面试过程中,面试官会问到实际应用场景的问题:比如微服务化、用户量、并发量、业务复杂度以及可扩展程度等,这里不多赘述。

3、微服务架构

微服务是现在互联网架构技术中最火热的话题之一,也是博主目前正在学习研究的方向。在阿里面试过程中,面试官很少会问到关于微服务相关的问题。但作为一名开发者,一名有技术梦想的程序员微服务架构是现在必须要去了解的主流技术。

微服务的内容过多,这里只列举了两个,需要了解更多的朋友可以帮忙转发文章后,关注后私信回复【学习】来免费获取更多微服务的思维脑图和相关资料

5、性能优化

性能一直是让程序员比较头疼的问题。当系统架构变得复杂而庞大之后,性能方面就会下降,特别是阿里巴巴这样的一线互联网公司最为注重,因此想进入阿里,性能优化一定是要去深入学习与理解的一环。

6.设计模式

设计模式(Design pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。 毫无疑问,设计模式于己于他人于系统都是多赢的,设计模式使代码编制真正工程化,设计模式是软件工程的基石,如同大厦的一块块砖石一样。项目中合理的运用设计模式可以完美的解决很多问题,每种模式在现在中都有相应的原理来与之对应,每一个模式描述了一个在我们周围不断重复发生的问题,以及该问题的核心解决方案,这也是它能被广泛应用的原因。

完整进阶架构大纲

Spring源码100集

这是我初学源码时的视频资料;需要的小伙伴可找我免费获取;

 

路已经给你指明了,往前走就行;冲吧皮卡丘!

 

壮士记得点个关注再走哦!