学习内核的好处不少,在学习过程当中不只能够夯实大量理论基础,还能够学习到不少编码惯用法,提高学习能力和分析能力。node
1、确立高度,明确目标linux
在学习内核过程当中最容易犯的错误,也是很是难掌握的实际上是你站在一个什么样的高度上去学习。站什么样的高度去学习也与自身的能力相关,因此这个问题其实更可能是在新开始学习的学习者感到很是痛苦的一件事。一方面又但愿本身能学懂,可是又不知道如何开始入手。编程
我列举几个常见的例子:网络
(1) 一开始就看源码,最开始我也作过这种事,内核有什么都不知道,结果就想着啃0.11的内核,结果很显然,2天立马放弃,彻底看不懂。架构
(2) 翻开书从第一页开始往下啃,若是这本书比较薄还好,若是比较厚,好比《深刻Linux内核架构》,那看2天也得放弃。函数
(3) 不喜欢看目录,不喜欢快速浏览,就想着一个一个字眼的往下抠。若是自己有必定基础,看的时候还不会以为腻,可是很快就发现,看了半天,什么都没有记住。学习
还有不少相似的问题,这些都是咱们平时学习的时候特别容易出现的一些误区。这些其实都是没有正确审视本身的能力,胡乱挑选高度致使。编码
高度越高,也就是越偏向于理解各类抽象概念,倾向于构建对总体结构的一个认知,忽略一些没必要要细节,不关心技术实现手段。高度越低,也就是越偏向于对使用技术的选择,倾向于代码实现的各个细节,可是前提通常会在某个抽象的概念领域内进行各类细节性的讨论。spa
咱们的大脑更倾向于理解抽象的内容,可是在行动时,咱们却更倾向于去把握细节性的内容。结果致使的内容就是,咱们老是但愿经过学习细节来构造对抽象概念的理解,最后被细节性内容中各类噪声干扰思绪,产生一种“这东西好难”的错觉。在理解了这点,那高度对咱们的行为有和指导意义也就呼之欲出了?
以读书为例。站的越高,意味着本身看的内容越粗糙,也就是看书的时候不会去逐字逐句的看,而是一个章节一个章节的看,极端的状况就是只看目录,在这个过程当中主要集中精力构建总体结构,对核心的概念进行抽象。这时候学的内容都相对表面,可是好处就是对之后的学习有很强的指导意义,缺点很明显,会让人底气不足,并且在达到必定程度后,很容易到达瓶颈,发觉怎么看都看不懂了。站的越低,意味着本身看的内容很细致,看书的时候就是一个个字眼的扣,极端状况就是开始阅读源码,去看开源社区的各类问题。可是就像诗句说的,站的越低,也就常有一种“不识庐山真面目,只缘身在此山中”的感受。这种状况下特别容易被各类细节干扰,例如为何要有这些参数,为何这里须要判断这个条件等等这些细枝末节的问题。设计
之前对一篇博文印象很深入,做者理解的学习曲线划分红了两个比较大的过程,上升的过程就是一个不断学习积累的过程,而平缓没有增加的过程则是对以前积累到饱和的知识进行消化的过程。我将这个学习过程进行进一步的划分,我以为在学习积累的前半部分应该以偏向学习抽象概念为主,而后半部分应该偏向学习实现细节。
因此我的的心得是从高到低的学习,在一个新的学习阶段,应该先多花点时间学习一些概念化的内容,这时候切忌去看具体的实现,而是多考虑如何在大脑中构建各类抽象模型
对总体的架构有所概念了,而后开始学习一些细节性的内容,好比开始看些源码,抠写书上的字眼,读读一些具体的博客什么的。
2、学习小Tips
不要从第一页开始翻 不要一页一页的翻
若是开始看代码,必定要记住,本身已经站在一个很是底层的高度度了,可以有能力阅读代码,就意味着你必须对总体的结构有比较清晰的认识,若是你都不知道这个结构,那看代码为时太早。
不管是什么样的代码,其实思路都很相似,即便Linux内核是用C这种面相过程的语言编写,可是这么多年发展下来,Linux内核已经带有了大量面对对象编程的特色。
在看代码的时候也是有两种不一样的高度能够选择,我先解释其中最细致的一种:
一个函数写下来常常上百行,可是你须要一行一行的看么?确定不能,那清晰认识一个函数的结构就很重要。
一个函数就是为了解决一个问题,函数名基本都能说明其功能,函数参数是输入,返回值就是输出,函数体就是总体的执行逻辑。在函数体内部,也基本都是相似的逻辑,先是对各类输入参数进行检查,而后书写功能逻辑,而后构造输出的结果。因此一个函数写下来老是这样的一种结构。
输出结果 函数名(输入)
{
if (输入的参数有问题)
{
异常处理,跳出
}
准备参数
功能逻辑
构造输出结果
返回输出结果
}
一个函数其实就是一个方法,阅读的难度比书写的难度要低,书写代码须要考虑的问题很是多,可是在阅读代码的时候问题就简单不少,不少书写代码过程当中须要考虑的问题在阅读代码的过程当中就不须要考虑 。
阅读代码还有不少技巧,例如如何在带有goto语句的代码中快速理解逻辑,如何界定那些注释是能够忽略的,如何将一些代码逻辑当作一块总体内容,什么时候应该跳到更深的一层函数阅读等等。这些都须要平时的经验积累。
看代码有一个粒度问题,咱们不能一行一行的看,也不能一个一个函数的看,我以前提到了,Linux内核有大量面向对象编程的影子,因此在看大量代码的时候,必须学会面向对象编程的思惟模式。这样对本身在大量代码阅读中提供大量参考意见。
或许有人会告诉你,面向对象编程就是弄明白什么是对象、如何写一个class就能够了。确实,学习面向对象编程,弄明白对象是基础,不过我以为能够再拔高一点,理解一些更抽象的概念,在这些抽象概念的指导下去学习,能够有更多的指导意义。
若是可以理解上述的这几个抽象,那在大量代码中如何游刃有余就相对容易了,有一个简单的套路:
(1) 在较高的角度,弄明白一个系统为了解决什么问题,应该有哪些抽象
(2) 在对总体结构有所了解之后,花心思看看这些抽象对应的领域模型,由于通常状况领域模型很庞大,因此看的时候也须要有步骤的进行拆解学习。
(3) 在对领域模型有所了解后,开始看领域驱动类,想明白为何会有这些操做。
(4) 在上述准备好后,就能够花费一些时间去看各个函数的具体实现,而且在看的过程当中多思考领域模型为何这么设计。