README.md 15.3 KB
Newer Older
1
[![在这里插入图片描述](https://gitee.com/weharmony/docs/raw/master/pic/other/io.png)](https://weharmony.gitee.io)
2
鸿蒙内核源码注释仓库 >> 精读内核源码,中文注解分析, 深挖地基工程,大脑永久记忆, 四大源码仓每日同步更新[ < Gitee ](https://gitee.com/weharmony/kernel_liteos_a_note)[| Github ](https://github.com/kuangyufei/kernel_liteos_a_note)[| CSDN ](https://codechina.csdn.net/kuangyufei/kernel_liteos_a_note)[| Coding > ](https://weharmony.coding.net/public/harmony/kernel_liteos_a_note/git/files)
3

4
鸿蒙内核源码分析博客 >> 故事说内核,问答式导读,生活式比喻,表格化说明,图形化展示,主流站点每日同步更新[ < CSDN ](https://blog.csdn.net/kuangyufei/article/details/108727970)[| 开源中国 ](https://my.oschina.net/u/3751245/blog/4626852)[| WeHarmony >](https://weharmony.gitee.io/)
5

6
---
7

8
## **为何要精读内核源码?**
9

鸿蒙内核源码分析's avatar
鸿蒙内核源码分析 已提交
10
每个码农,学职生涯,都应精读一遍内核源码.是浇筑计算机知识大厦的地基工程,地基纵深坚固程度,决定了大厦能盖多高。为何一定要精读?因为内核代码本身并不太多,都是浓缩的精华,精读就是让各个知识点高频出现,闪爆大脑,短时间内容易结成一张高浓度,高密度的底层网,形成永久大脑记忆。跟骑单车一样,一旦学会,即便多年不骑,照样跨上就走,游刃有余。
11

12
## **做了些什么呢?**
13

14
**[WeHarmony/kernel\_liteos\_a_note](https://gitee.com/weharmony/kernel_liteos_a_note)** 是在鸿蒙官方开源项目 **[OpenHarmony/kernel\_liteos\_a](https://gitee.com/openharmony/kernel_liteos_a)** 基础上给源码加上中文注解的版本,目前几大核心模块加注已基本完成, **整体加注完成70%**, 正持续加注完善中 ...
15

16
### **2020/9/10**
17
    
18
因大学时阅读linux 2.6 内核痛苦经历,一直有个心愿,如何让更多对内核感兴趣的同学减少阅读时间,加速对计算机系统级的理解,而不至于过早的放弃.但因过程种种,多年一直没有行动,基本要放弃这件事了. 恰逢 2020/9/10 鸿蒙正式开源,重新激活了多年的心愿,就有那么点一发不可收拾了. :|P
19
    
20
### **致敬鸿蒙内核开发者**
21
    
22
感谢开放原子开源基金会,鸿蒙内核开发者提供了如此优秀的源码,一了多年的夙愿,津津乐道于此.精读内核源码当然是件很困难的事,时间上要以月甚至年为单位,但正因为很难才值得去做! 干困难事,必有所得. 专注聚焦,必有所获. 致敬内核开发者,从内核一行行的代码中能深深体会到开发者各中艰辛与坚持,及鸿蒙生态对未来的价值,可以毫不夸张的说鸿蒙内核源码可作为大学C语言,数据结构,操作系统,汇编语言 四门课程的教学项目.如此宝库,不深入研究实在是暴殄天物,于心不忍,注者坚信鸿蒙大势所趋,未来可期,是其坚定的追随者和传播者.
23

24
### **加注方式是怎样的?**
25
    
26
因鸿蒙内核6W+代码量,本身只有较少的注释, 中文注解以不对原有代码侵入为前提,源码中所有英文部分都是原有注释,所有中文部分都是中文版的注释,尽量不去增加代码的行数,不破坏文件的结构,试图把知识讲透彻,注释多类似以下的方式:
27

28
在每个模块的.c文件开始位置先对模块功能做整体的介绍,例如异常接管模块注解如图所示:
29

30
![在这里插入图片描述](https://gitee.com/weharmony/docs/raw/master/pic/other/ycjg.png)
31

32
注解过程中查阅了很多的资料和书籍,在具体代码处都附上了参考链接.
33

34
而函数级注解会详细到重点行,甚至每一行, 例如申请互斥锁的主体函数,不可谓不重要,而官方注释仅有一行,如图所示
35

36 37 38 39 40 41 42
![在这里插入图片描述](https://gitee.com/weharmony/docs/raw/master/pic/other/sop.png)

另外画了一些字符图方便理解,直接嵌入到头文件中,比如虚拟内存的全景图,因没有这些图是很难理解虚拟内存是如何管理的.

![在这里插入图片描述](https://gitee.com/weharmony/docs/raw/master/pic/other/vm.png)

### **理解内核的三个层级**
43
    
44
注者认为理解内核可分三个层级:
45

46 47 48
**第一: 普通概念映射级** 这一级不涉及专业知识,用大众所熟知的公共认知就能听明白是个什么概念,也就是说用一个普通人都懂的概念去诠释或者映射一个他们从没听过的概念.说别人能听得懂的话这很重要!!! 一个没学过计算机知识的卖菜大妈就不可能知道内核的基本运作了吗? 不一定!,在系列篇中试图用 
鸿蒙内核源码分析(总目录) | 精读内核源码 深挖地基工程[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108727970) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4626852)|[ WeHarmony > ](https://weharmony.gitee.io)
必读故事篇去引导这一层级的认知,希望能卷入更多的人来关注基础软件,尤其是那些资本大鳄,加大对基础软件的投入.
49

50 51 52
**第二: 专业概念抽象级** 对抽象的专业逻辑概念具体化认知, 比如虚拟内存,老百姓是听不懂的,学过计算机的人都懂,具体怎么实现的很多人又都不懂了,但这并不妨碍成为一个优秀的上层应用程序员,因为虚拟内存已经被抽象出来,目的是要屏蔽上层对它的现实认知.试图用
鸿蒙内核源码分析(总目录) | 精读内核源码 深挖地基工程[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108727970) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4626852)|[ WeHarmony > ](https://weharmony.gitee.io)
去拆解那些已经被抽象出来的专业概念, 希望能卷入更多对内核感兴趣的应用软件人才流入基础软件生态, 应用软件咱们是无敌宇宙,但基础软件却很薄弱.
53

54
**第三: 具体微观代码级** 这一级是具体到每一行代码的实现,到了用代码指令级的地步,这段代码是什么意思?为什么要这么设计? **[鸿蒙内核源码注释中文版](https://gitee.com/weharmony/kernel_liteos_a_note)** 试图从细微处去解释代码实现层,英文真的是天生适合设计成编程语言的人类语言,计算机的01码映射到人类世界的26个字母,诞生了太多的伟大奇迹.但我们的母语注定了很大部分人存在着自然语言层级的理解映射,希望注释中文版能让更多爱好者快速的理解内核,共同进步.
55

56
## **主流站点**
57

58
感谢开源中国,CSDN,51CTO,电子发烧友,以及其他小伙伴通过自己的公众号对系列文章的转载和推荐,无以为报,唯有不断的深挖内核地基,输出更多文章,错漏之处请多见谅,会持续完善源码注解和文档内容,精雕细琢,尽全力打磨精品内容。以下是博客的输出站点
59

60
**[公众号 |](https://gitee.com/weharmony/docs/raw/master/pic/other/wxcode.png)** **[WeHarmony |](https://weharmony.gitee.io)** **[CSDN |](https://blog.csdn.net/kuangyufei/article/details/108727970)** **[开源中国 |](https://my.oschina.net/u/3751245/blog/4626852)** **[51CTO](https://harmonyos.51cto.com/column/34)**   
61

62
## **鸿蒙源码分析系列篇**
63

64
### **总纲** 
65

66
(总目录) | 精读内核源码 深挖地基工程[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108727970) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4626852)|[ WeHarmony > ](https://weharmony.gitee.io)
67

68 69 70 71 72 73 74 75 76 77 78
### **故事篇**

(调度故事篇) | 西门和金莲的那点破事 [<  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108745174) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4634668)|[ WeHarmony > ](https://weharmony.gitee.io)

(内存主奴篇) | 紫禁城的主子和奴才如何相处? [<  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108723672) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4646802)|[ WeHarmony > ](https://weharmony.gitee.io)

### **进程+线程**

(调度机制篇) | 任务是如何被调度执行的?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108705968) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4623040)|[ WeHarmony > ](https://weharmony.gitee.io)

(调度队列篇) | 就绪队列对调度的作用[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108626671) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4606916)|[ WeHarmony > ](https://weharmony.gitee.io)
79

80
(任务管理篇) | 任务是内核调度的单元[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108621428) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4603919)|[ WeHarmony > ](https://weharmony.gitee.io)
81

82
(时钟任务篇) | 调度最大的动力来自哪里?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108603468) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4574493)|[ WeHarmony > ](https://weharmony.gitee.io)
83

84
(进程管理篇) | 进程是内核资源管理单元[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108595941) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4574429)|[ WeHarmony > ](https://weharmony.gitee.io)
鸿蒙内核源码分析's avatar
鸿蒙内核源码分析 已提交
85

86
(线程概念篇) | 线程,线程,它到底长什么样?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/112870193) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4915543)|[ WeHarmony > ](https://weharmony.gitee.io)
87

88
(进程概念篇) | 进程都管理了哪些资源?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/113395872) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4937521)|[ WeHarmony > ](https://weharmony.gitee.io)
89

90
### **内存篇**
91

92
(物理内存篇) | 伙伴算法是在卖标准猪肉块吗?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/111765600) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4842408)|[ WeHarmony > ](https://weharmony.gitee.io)
93

94
(内存规则篇) | 内存管理到底在管什么?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/109437223) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4698384)|[ WeHarmony > ](https://weharmony.gitee.io)
95

96
(内存映射篇) | 虚实内存是如何映射的?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/109032636) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4694841)|[ WeHarmony > ](https://weharmony.gitee.io)
97

98
(内存汇编篇) | 什么是虚拟内存的实现基础?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108994081) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4692156)|[ WeHarmony > ](https://weharmony.gitee.io)
99

100
(内存分配篇) | 内存有哪些分配方式?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108989906) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4646802)|[ WeHarmony > ](https://weharmony.gitee.io)
101

102
(内存管理篇) | 虚拟内存全景图是怎样的?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108821442) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4652284)|[ WeHarmony > ](https://weharmony.gitee.io)
103

104
(内存主奴篇) | 紫禁城的主子和奴才如何相处?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108723672) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4646802)|[ WeHarmony > ](https://weharmony.gitee.io)
105

106
### **基础篇**
107

108
(汇编传参篇) | 汇编如何传递复杂的参数?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/113265990) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4927892)|[ WeHarmony > ](https://weharmony.gitee.io)
109

110
(汇编基础篇) | CPU在哪里打卡上班 ?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/112986628) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4920361)|[ WeHarmony > ](https://weharmony.gitee.io)
111

112
(用栈方式篇) | 栈是构建底层运行的基础[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/112534331) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4893388)|[ WeHarmony > ](https://weharmony.gitee.io)
113

114
(位图管理篇) | 为何进程和线程都是32个优先级?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/112394982) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4888467)|[ WeHarmony > ](https://weharmony.gitee.io)
115

116
(源码结构篇) | 内核500问你能答对多少?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/111938348) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4869137)|[ WeHarmony > ](https://weharmony.gitee.io)
117

118
(源码注释篇) | 精读内核源码有哪些好处?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/109251754) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4686747)|[ WeHarmony > ](https://weharmony.gitee.io)
119

120
(双向链表篇) | 谁是内核最重要结构体?[ <  CSDN ](https://blog.csdn.net/kuangyufei/article/details/108585659) [|  开源中国 ](https://my.oschina.net/u/3751245/blog/4572304)|[ WeHarmony > ](https://weharmony.gitee.io)
121
    
122
### **Fork Me**
123

124
注解几乎占用了所有的空闲时间,每天都会更新,每天都有新感悟,一行行源码在不断的刷新和拓展对内核知识的认知边界. 对已经关注和fork的同学请及时同步最新的注解内容. 内核知识点体量实在太过巨大,过程会反复修正完善,力求言简意赅,词达本意.肯定会有诸多错漏之处,请多包涵. :)  
125

126
### **有哪些特殊的记号**
127

128
搜索 **[@note_pic]()** 可查看绘制的全部字符图
129

130
搜索 **[@note_why]()** 是尚未看明白的地方,有看明白的,请Pull Request完善
131

132
搜索 **[@note_thinking]()** 是一些的思考和建议
133

134
搜索 **[@note_#if0]()** 是由第三方项目提供不在内核源码中定义的极为重要结构体,为方便理解而添加的。
135

136
搜索 **[@note_good]()** 是给源码点赞的地方    
137

138
### **新增zzz目录**
139

140
中文加注版比官方版无新增文件,只多了一个zzz的目录,里面放了一些文件,它与内核代码无关,大家可以忽略它,取名zzz是为了排在最后,减少对原有代码目录级的侵入,zzz的想法源于微信中名称为AAA的那帮朋友,你的微信里应该也有他们熟悉的身影吧 :|P
141
    
142 143
### **参与贡献**
1. Fork 本仓库 >> 新建 Feat_xxx 分支 >> 提交代码注解 >> [新建 Pull Request](https://gitee.com/weharmony/kernel_liteos_a_note/pull/new/weharmony:master...weharmony:master)
144

145
2. [新建 Issue](https://gitee.com/weharmony/kernel_liteos_a_note/issues)
146

147 148
### **喜欢就请注入源动力吧**

149
各大站点搜 **"鸿蒙内核源码分析"** ,快速找到组织.或者更简单的,如图:
150 151

![公众号: 鸿蒙内核源码分析](https://gitee.com/weharmony/docs/raw/master/pic/other/so1so.png)
152

153
---
154

155
鸿蒙内核源码注释仓库 >> 精读内核源码,中文注解分析, 深挖地基工程,大脑永久记忆, 四大源码仓每日同步更新[ < Gitee ](https://gitee.com/weharmony/kernel_liteos_a_note)[| Github ](https://github.com/kuangyufei/kernel_liteos_a_note)[| CSDN ](https://codechina.csdn.net/kuangyufei/kernel_liteos_a_note)[| Coding > ](https://weharmony.coding.net/public/harmony/kernel_liteos_a_note/git/files)
156

157
鸿蒙内核源码分析博客 >> 故事说内核,问答式导读,生活式比喻,表格化说明,图形化展示,主流站点每日同步更新[ < CSDN ](https://blog.csdn.net/kuangyufei/article/details/108727970)[| 开源中国 ](https://my.oschina.net/u/3751245/blog/4626852)[| WeHarmony >](https://weharmony.gitee.io/)