如何阅读源码(如何读懂源码)

本篇文章给大家谈谈如何阅读源码,以及如何读懂源码对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

如何阅读源代码

一个大项目的源代码,不要过份详细的阅读。大项目,其代码量基本上是可以吓死人的。过份的关注细节,常常会拘泥于细节,而忽略了整体框架。当你能够看清框架的时候,亦花费了太多的时间。

因此,阅读一个大项目的源代码,其目的不在于欣赏代码细节,而在于迅速看清项目整体框架的大概面貌:都有那些模块,这些模块是干嘛的(不关心具体怎么干),模块之间的通讯机制大概是怎样的,然后在考虑子模块,通常只要掌握两级子模块就够了。花上1,2天的时间掌握这一切,就达到了阅读大项目源码的目的。因为一旦你掌握了框架,你就可以按照这个框架实现这个项目,虽然和原项目全然不同,但是完成的需求却是一样的。

在软件中,架构才是本质。

也许你指望详细阅读大项目源代码能看到高质量的代码,但是,大项目通常都是团队的劳动成果,每个人的不同水平造就了代码质量的高高低低,一个人在不同时间不同环境的代码质量也是不同的。要指望在大片源码面前找到高质量,简直是天方夜谭。

也许你要从阅读源码中掌握某项技术细节,比如bsp,又或者换装,那么,最好的建议是查找相关的技术文档以及文档上所附带的sample code,这种sample code一般不会附带任何干扰,简洁得只是为了证明该技术而存在的。如果没有这些东西,而只能从大项目源码中找的话,你提前先了解了框架,能更快的查找和定位到表达该技术的文件。但是通常都会比较不幸,因为你为了明白这一技术,通常要先理解混入其中的另一技术。

最后谈谈怎样才能阅读到高质量的源代码。何谓高质量?是指算法出人一表(比如某种o(1)的排序法)?还是采用了极端深奥的语言特性将某实现完美表达(比如模板的灵活运用)?无论是哪种,最好的来源是书,如《STL详解》,或者《inside XX》这样的东西。书的作者通常就是这些高质量代码的作者,他会带领你探索这些源码背后的真相。

怎么阅读内核源代码?

一般在Linux系统中的/usr/src/linux*.*.*(*.*.*代表的是内核版本,如2.4.23)目录下就是内核源代码(如果没有类似目录,是因为还没安装内核代码)。另外还可从互连网上免费下载。注意,不要总到去下载,最好使用它的镜像站点下载。请在里找一个合适的下载点,再到pub/linux/kernel/v2.6/目录下去下载2.4.23内核。

代码目录结构

在阅读源码之前,还应知道Linux内核源码的整体分布情况。现代的操作系统一般由进程管理、内存管理、文件系统、驱动程序和网络等组成。Linux内核源码的各个目录大致与此相对应,其组成如下(假设相对于Linux-2.4.23目录):

1.arch目录包括了所有和体系结构相关的核心代码。它下面的每一个子目录都代表一种Linux支持的体系结构,例如i386就是Intel CPU及与之相兼容体系结构的子目录。PC机一般都基于此目录。

2.include目录包括编译核心所需要的大部分头文件,例如与平台无关的头文件在include/linux子目录下。

3.init目录包含核心的初始化代码(不是系统的引导代码),有main.c和Version.c两个文件。这是研究核心如何工作的好起点。

4.mm目录包含了所有的内存管理代码。与具体硬件体系结构相关的内存管理代码位于arch/*/mm目录下。

5.drivers目录中是系统中所有的设备驱动程序。它又进一步划分成几类设备驱动,每一种有对应的子目录,如声卡的驱动对应于drivers/sound。

6.ipc目录包含了核心进程间的通信代码。

7.modules目录存放了已建好的、可动态加载的模块。

8.fs目录存放Linux支持的文件系统代码。不同的文件系统有不同的子目录对应,如ext3文件系统对应的就是ext3子目录。

Kernel内核管理的核心代码放在这里。同时与处理器结构相关代码都放在arch/*/kernel目录下。

9.net目录里是核心的网络部分代码,其每个子目录对应于网络的一个方面。

10.lib目录包含了核心的库代码,不过与处理器结构相关的库代码被放在arch/*/lib/目录下。

11.scripts目录包含用于配置核心的脚本文件。

12.documentation目录下是一些文档,是对每个目录作用的具体说明。

一般在每个目录下都有一个.depend文件和一个Makefile文件。这两个文件都是编译时使用的辅助文件。仔细阅读这两个文件对弄清各个文件之间的联系和依托关系很有帮助。另外有的目录下还有Readme文件,它是对该目录下文件的一些说明,同样有利于对内核源码的理解。

在阅读方法或顺序上,有纵向与横向之分。所谓纵向就是顺着程序的执行顺序逐步进行;所谓横向,就是按模块进行。它们经常结合在一起进行。对于Linux启动的代码可顺着Linux的启动顺序一步步来阅读;对于像内存管理部分,可以单独拿出来进行阅读分析。实际上这是一个反复的过程,不可能读一遍就理解。

如何读JAVA源码

本来不想回答,翻到下面那些答复实在看不过去,就花点功夫整理下吧,希望对有人心能有帮助。

阅读分析源代码,一些有效的方法是:

1、阅读源代码的说明文档和API文档。

2、如果源代码有用法示例或向导,先阅读这个。

3、了解整个项目的模块结构,可以按模块进行阅读。

4、随时使用查找功能(或超链接)阅读关联类或关联方法。

5、对于有疑问的地方,不妨写几行单元测试。

6、由浅入深,由易到难,多阅读优秀的开源项目,代码阅读水平会突飞猛进。

怎么阅读spring源码

从HttpServletBean的init()进入,再到initWebApplicationContext(),再到refresh(),再到refreshBeanFactory(),再到finishRefresh(),直到服务器启动成功。不知道读了多少遍,

但是源码的东西实在的太多了,想要完全读懂,完全理清头绪,还差很远啊。所以我只重点关注了两块内容,就是bean的定位加载解析注册、bean的实例化两大块内容,其他地方稍作了解,没有太过深入。

整个容器的启动流程,都在AbstractApplicationContext的refresh()的模板方法中了。

复制代码

1 public void refresh() throws BeansException, IllegalStateException {

2 synchronized (this.startupShutdownMonitor) {

3 // Prepare this context for refreshing.

4 prepareRefresh();

5

6 // Tell the subclass to refresh the internal bean factory.

7 ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory();

8

9 // Prepare the bean factory for use in this context.

10 prepareBeanFactory(beanFactory);

11

12 try {

13 // Allows post-processing of the bean factory in context subclasses.

14 postProcessBeanFactory(beanFactory);

15

16 // Invoke factory processors registered as beans in the context.

17 invokeBeanFactoryPostProcessors(beanFactory);

18

19 // Register bean processors that intercept bean creation.

20 registerBeanPostProcessors(beanFactory);

21

22 // Initialize message source for this context.

23 initMessageSource();

24

25 // Initialize event multicaster for this context.

26 initApplicationEventMulticaster();

27

28 // Initialize other special beans in specific context subclasses.

29 onRefresh();

30

31 // Check for listener beans and register them.

32 registerListeners();

33

34 // Instantiate all remaining (non-lazy-init) singletons.

35 finishBeanFactoryInitialization(beanFactory);

36

37 // Last step: publish corresponding event.

38 finishRefresh();

39 }

40

41 catch (BeansException ex) {

42 // Destroy already created singletons to avoid dangling resources.

43 destroyBeans();

44

45 // Reset 'active' flag.

46 cancelRefresh(ex);

47

48 // Propagate exception to caller.

49 throw ex;

50 }

51 }

52 }

其实,我并没有上来就看源码,而是先从看书开始,稍微了解,知道了一些关键点,关键流程,自己产生了一堆疑问,然后带着疑问去读源码,读着读着,发现有些疑问就这么解决了。

如何阅读wordpress源码

一。先把源代码安装起来,结合它的文档和手册,熟悉其功能和它的应用方式。

二。浏览源代码的目录结构,了解各个目录的功能。

三。经过以上两步后相信你对这个开源的产品有了一个初步的了解了,那现在就开始分析它的源码吧。这一步我们开始分析源代码框架。例如入口方式是单入口还是多入口,页面之间的调用规则,能根据规则找出某个功能用到的页面。

四。熟悉源代码的代码写作风格,例如缩进方式,排版格式等。

五。熟悉一下源代码用到的数据库和表,可以参考它的技术支持文档。

六。经过以上几步相信大家已经对这份源代码有了更深刻的了解,不过这种了解还只是表面的,下来我们从6个方面具体的去分析它吧:

1.入口构造以及页面调用方式的具体实现,如果阅读时看到工具类和工具函数,尽量去熟悉一下。这一步的分析可以学习到源代码的系统架构方式。

2.分析源代码用到的工具类和工具函数,这样可以学到很多程序编写技巧。可以提升自己编程功力。

3.结合一些安全规则,研究这个源代码是怎样实现安全方面的设计的。这样可以提高自己在安全方面的意识和功力。

4.如果有模板引擎的话,研究一下源代码的模板引擎。大致从实现方式,效率,易用性等几个方面去考虑。

5.研究系统的各个功能模块,这样既能学习编程技巧还能打开自己的编程思路,下次遇到类似的东东就心里有谱了。

6.研究系统所用到设计模式,一样的功能实现,用到的设计模式可能相差很多,对比我们之前所作的东东分析设计模式,是提升我们驾驭代码的不二法门。

7.研究源代码对访问压力,执行效率,系统效率,数据库查询的优化。

如何阅读Nutz的源码

     

开始学习框架思想了,打算先从nutz入手,因为nutz是国人写的,中文注释,容易理解

而且nutz框架比较小,但是麻雀虽小五脏俱全,大牛的思想还是可以学到的.

1、

这个是log的包信息,基本上有了一个大题的介绍

2.接口 public interface Log

五个级别trace,info,warn,debug,fatal这个都比较容易理解

提供了3个约等于重载的方法

他提工具了一个抽象实现类,实现了部分功能但是主要的输出还是在两个适配器中的内部类进行输出的

这个AbstractLog  提供了一个主要的方法makeInfo目的就是产生下面介绍的LogInfo 对象,

对之前的方法重载做统一处理

但是输出地还是在适配器的内部类当中

static class Log4JLogger extends AbstractLog

static class SystemLog extends AbstractLog

3.信息 LogInfo 定义的比较简单信息message,异常Throwable

4.日志适配器   (适配器模式出来了哈,不过我也用过适配器模式)  LogAdapter

这里就把system.out.print和log4j进行了适配,再利用他的插件机制,动态获取

传送门

这里只定义一个方法获取log其实需要的也就这个

他提供3个适配器

1.NopLog 什么都不干适配器

2.SystemLogAdapter 这个应该很明显了输出到控制台

3.Log4jLogAdapter 这个应该是最常用也是最主要用的

不过最好再提供个SLF4jLogAdapter 这样看nuth的扩展性存在一点小问题

他是在这里写死的,不如配置的容易定义

5.Logs 这个也是最主要最常用的了

他静态初始化了适配器的

private static LogAdapter adapter;

然后提供静态方法 getLog这样就想平常一样调用上面的输出了

这里if感觉多此一举,既然这样判断何不在warn里面判断呢(效率问题),感觉这样写法有点蛋疼,

关于如何阅读源码和如何读懂源码的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


【免责声明】:

本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

【关于转载】:

本站尊重互联网版权体系,本站部分图片、文章大部分转载于互联网、所有内容不代表本站观点、不对文章中的任何观点负责、转载的目的只用于给网民提供信息阅读,无任何商业用途,所有内容版权归原作者所有
如本站(文章、内容、图片、视频)任何资料有侵权,先说声抱歉;麻烦您请联系请后台提交工单,我们会立即删除、维护您的权益。非常感谢您的理解。

【附】:

二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

注:本站资源来自网络转载,版权归原作者和公司所有,如果有侵犯到您的权益,请第一时间联系我们处理!

-----------------------------------------------------------------------------------------------------------

【版权声明】:

一、本站致力于为源码爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、如有内容侵犯您的版权或其他利益的,请编辑邮件并加以说明发送到站长邮箱。站长会进行审查之后,情况属实的会在三个工作日内为您删除。
-----------------------------------------------------------------------------------------------------------


内容投诉
源码村资源网 » 如何阅读源码(如何读懂源码)
您需要 登录账户 后才能发表评论

发表评论

欢迎 访客 发表评论