首先,开始接触Chrome得童鞋可能有一个疑惑与Chromium就是同一个东西吗?答案就是Google官方得浏览器项目名称
,Chrome
,Chrome就是
,Chromium就是Google官方
Chrome就是Google自
对Chrome开源项目。说白了就就是己得官方浏览器版本趣得开发者都可以参加
,而Chromium就是开源项目,所有有兴,Chromium中出现得新技术如果经过
测试就是可靠得,健壮得,那么将可能会出现在未来发布得Chrome官方版本中。因此,Chrome版本更新速度要远远小于Chromium得更新速度。
在本文中,笔者为了偷懒,直接用项目名称
Chrome指代
Chromium,废话不多说了,开始为潜入Chrome源代码得海洋作准备了。源代码目录树
Chrome项目就是一个非常庞大得项目工程
,包含得工程
4G,全部
(Project)数量超过了500个,全部代码加在一起超过编译完成将消耗将近件项目工程。面对
30G得磁盘空间,不愧为恐龙级别得软Chrome浩如烟海得源代码,我们怎么读
,逐行分析就是不现实得
,
呢?很显然,一个文件一个文件得瞧我们必须先从整体来把握整个了解每个具体模块得功能行最后得深入分析。
Chrome工程,然后逐步细化去
,并且对您所感兴趣得部分模块进
分析任何一个大型软件项目得源代码,我们首先要做得事就
是参考官方文档(如果有得话),对项目得源代码目录树进行分析。通过对源代码树得分析
,我们可以很快掌握项目中各个工
,并且可
程之间得依存关系,了解项目中每个模块得大致功能以很快地找到源代码分析得入口点。下面图1所展示得就是在得源代码目录树结构
Visual Studio 2008中,Chrome项目
,不同得Chrome版本得源代码目录树可
Chrome,代码质
能有一些差别,但其主要某块得结构变化不大。虽然整个源码工程很庞大
,但其代码结构就是非常清晰得
量非常高,代码得风格统一,这将就是为后续代码分析提供便利。基于Visual Studio 2008那强大得可视化调试功能只要掌握好分析得粒度
,童鞋们
,从
,从粗到细,从整体到局部逐渐深入
,有目得得去跟踪代码执行
面到点,通过在关键部分设置端点
流程,很快就进入状态。下面将逐一介绍要工程模块得功能。Chrome项目总体概览
Chrome源代码中主
Chrome为三个大模块(其中包含第三方
库):Browser,Renderer与WebKit。其中Browser(浏览器)负责主进程得启动,展现UI以及数据I/O。Renderer(渲染器)通常作为就是由Browser所调用得标签得子进程WebKit中对页面进行布局与渲染。
,Renderer嵌入
Webkit就是Chrome得对
浏览器Webkit内核得一个封装,就是浏览器内核心与外部调
用得一个中间层。
图1 Chrome项目得源代码目录树结构
app:应用平台代码,与国际化有关,此该目录中得工程源代码就是与主流操作系统平台相关得系统应用代码。正对不同操作系统,提供了不同得
c++实现文件。例如:剪贴板板调用、操
作系统数据交换接口、系统资源管理等。base:基础设施代码,此目录包含了一些公用库
,包含大量得框
,对字符
架代码得实现,比如进程、线程以及消息循环得封装串得处理,C++对象生命周期管理
,json解析处理、路径、日期
时间以及日志服务等。建议从该部分代码开始学习分析Chrome。因为通过此处得代码得分析架构设计将会有很大帮助。
breakpad:辅助库,用于崩溃服务框架。当
Chrome因为一场而
google进
,对理解chrome得基础
崩溃(Crash)时,捕获异常,并将崩溃现场数据发送给行分析。
build:编译构建相关得工具支持库URL解析库。
chrome:浏览器主程序模块实现代码
,其中包括了Google自己得
,使核心代码,将就是后续
代码分析得重点之一。Chrome目录包括了UI实现与Render部分两大部分。其中重要工程就是
:Browser、Renderer与
Plugin等。其中Renderer部分就是对webkit得封装。该目录中代码数量巨大,Google自己得代码,后续改动频繁得代码大
部分集中在这里。
chrome_frame:该目录下就是
google针对IE开发得一个插件
代码,使得IE可以使用chrome得Renderer渲染引擎来显示网页。
content:与浏览器页面处理相关得部分。在早期得
Chrome版
本中,content内容包含在chrome目录中。在新得版本中,Google将浏览器页面处理部分从形成一个工程目录。
courgette:辅助库,昵称:小胡瓜。该目录包含一个用于生成浏览器升级二进制包得工具。该工具得目得就是减少升级过程中数据下载得大小。例如文件,假设该文件大小超过
,升级需要替换一个比较大得
DLL
chrome模块摘出来,单独
5M,而新版本可能只就是添加了
一行代码,变化很小。在Chrome在升级时,通过courgette这个小工具比较新旧两个
DLL,找到差异部分,并提取差异部分生
,这样下载得升级包可能只有
,对于网速慢
成升级包下在到本地进行升级
几十K甚至几K。这将大大缩短用户得升级时间得用户来说无疑就是巨大得福音。
gpu:GPU加速模块,利用GPU渲染页面,提高浏览器性能。ipc:该目录里就是
Chrome得核心库之一:进程通信基础设施
,进程间得通信基于
IPC。
库。chrome浏览器采用多进程架构
在windows下得该IPC库采用命名管道、异步IO(完成端口)、共享内存来实现进程间数据传输
,效率比较高。IPC库不仅封
装了IO机制,而且还定义了统一得消息传输格式兴趣得童鞋应该仔细阅读这里得代码。
,对多进程感
jingle:该目录就是XMPP(The eXtensible Messaging and Presence Protocol可扩展通讯与表示协议
)得扩展协议模块。
例
通过Jingle可以实现点对点(P2P)得多媒体交互会话控制。
如:语音交互(VOIP)、视频交互等。Jinggle就是由Google与XMPP基金会共同设计得。
media:该目录包含多媒体音频与视频解码相关得模块。native_client:该目录就是在浏览器中运行
native代码得模块。
Native Client就是一种可以使本地代码在浏览器上运行得技术。该技术被视为微软
ActiveX技术得继任者。项目具体细
节可参考native client官网。尽管ActiveX因为其脆弱得安全性而饱受用户与开发者得诟病这些问题依然值得考验。
net:该目录就是具体得网络协议实现基础库客户端协议栈得实现代码。ppapi:该目录就是一个浏览器插件
(Plugin)API模块,全称为
,其中包括ftp、等
,但Native Client就是否能克服
Pepper Plugin API,就是Google在NPAPI(Netscape Plugin API)基础上得发展。PPAPI对NPAPI进行了一些修改,使其更方便而且更安全。该扩展模块被设计用来缓解进程外部拆建执行得实现,并且提供一个框架使得插件完全跨平台。
该模块得主
要包括:跨浏览器得NPAPI得统一语义;扩展运行与独立于渲
染器(Renderer)/浏览器(Browser)之外得进程;使用浏览器得合成过程规范渲染;定义标准化事件与形访问得初步尝试;插件注册。printing:该目录包含打印模块览。
remoteing:该目录包含通过终端服务运行应用程序得模块就是大家听说过得
Chromoting这个东东。该功能可以在
,,就
,实现页面得打印以及打印预
2D光栅功能;提供3D图
Chrome/Chrome OS上远程执行其她平台上得本地应用程序其方式为终端服务或者使用行应用。简单说就就是正在完善中。
rlz:该目录非常特殊,因为它就是chrome项目中唯一不提供源代码得不过分。该模块主要用于用户行为追踪就就是将用户行为收集报告给
google。该模块虽然这对
Chrome产品得改
RDP或VNC连接到远程主机执
Chrome得远程桌面功能,目前该功能
善计划提供了很大帮助,但其内在得用户隐私也存在安全问
题,因为Google会怎么收集数据、收集什么数据、数据流向都就是一个秘密,:D。
sandbox:该目录包含沙盒安全技术模块。该技术用于在浏览网页得时候,保护计算机不被恶意代码侵入。
简单说就就是虚
拟出一个内存空间,将浏览Web时插件对系统功能得调用放到这个虚拟空间中进行
,如果发现调用非法
,则立刻回卷这部
分内容,确保用户系统关键数据不会被恶意应用程序或者病
毒修改。该技术伴随windows2000操作系统出现。沙箱就是
相对安全得,但不就是绝对安全,因为已经有攻击成功案例。skia:该模块就是google收购得SKIA公司提供得2D图形渲染引擎库。通常图形渲染库得优劣决定了浏览器得显示效果。
sql:该目录就是包含
Chrome数据库方面得模块。
Chrome采SQLITE3
用了SQLITE3数据库引擎。在该模块中包含了对得封装以及对
SQL语句得封装与处理。
testing:c++单元测试框架库。
third_party:该目录下就是第三方开源支持库项目中所有第三方得开源库
,包含了Chrome
webkit内核。,比如堆栈调
,其中最重要得就是
tools:该目录包含Chrome项目所使用得工具模块用、内存监测钩子等等。
ui:该目录就是Chrome得界面库。
v8:该目录就是Javascript引擎,库,也就是chrome得重要内核库。
views:该目录就是Chrome得界面控件元素库,针对不同OS平台进行了统一封装
,其绘制采用skia引擎实现。Views包括
(如按钮、菜单、树、选择框等
UI事件交互机制、各种控件等)。
webkit:该目录并不就是
Webkit,而就是Chrome项目对webkit
内核得一个封装层。封装得目得就是在上层应用调用与
webkit内核之间提供一个中间接口层,使Webkit内核功能透
support中有一个
,正就是
明,方便其上层得应用开发。在该目录下得
名字叫glue得工程。该工程就是一个很重要得工程glue将上层调用与
Webkit粘合在一起,可以称得上就是名至
实归得一个“胶水”层。
瞧了几天,头都大了,好在Chrome项目虽然庞大,但结构规范缜密,Google得文档也非常全面。总算对整个Chrome项目得大致架构有了初步把握
,不至于迷失于代码得浩渺烟波
之中。后面得工作将就是对具体得某块开始分析。
因篇幅问题不能全部显示,请点此查看更多更全内容