您的位置:首页 > 其它

WebKit内核学习之二

2016-02-01 11:44 183 查看
自上次成功编译WebKit源码之后,已过去一些时日,为什么没有继续学习的原因就是,个人比较喜欢捣鼓计算机,编译完WebKit源码之后,我就借助工具清除了一下电脑的一些缓存文件,结果产生的后果就是,Ubuntu直接起不来了,实验了各种方法,依然桌面依然没有起来,没办法,只得重新安装系统,来来回回四五次,过程中也出现了各种的问题,也都通过请教和查阅资料,最终解决了,虽然过程崎岖,但是带来的最大的好处就是,我对于搭建工作编译环境,有了进一步的了解,知道该怎样去搭建工作环境了,终于将这个“技术活”转变为“体力活”了。
  在学习WebKit初期,个人认为要大致了解源码的框架结构,知道大的框架目录大致什么作用。

Webkit源代码由三大模块组成:

1). WebCore,

2). WebKit,

3). JavaScriptCore。

WebCore排版引擎核心,WebCore包含主要以下模块:Loader,Parser(DOM,Render),
Layout,Paint。
WebKit:移植层,主要包含:GUI,FileSystem,
Thread,Text,图片编解码等与平台相关的函数。
JavaScriptCore:JS虚拟机,相对独立,主要用于操作DOM,DOM是W3C定义的规范,主要用于定义外部可以操作的浏览器内核的接口,而webcore必须实现DOM规范。(具体的DOM规范可以查w3c.)

WebKit分模块介绍(这里简单列出因为能力有限也是初学者)

Webkit平台相关

CURL网络库

libPng,LibJpeg图形处理相关

sqlite小型关系数据库

WebCore核心

Loader加载资源及Cache实现(Curl)

DOM :HTML词法分析与语法分析

DOM :DOM节点与Render节点创建,形成DOM树

Render:Render树介绍,RenderBox

Layout:排版介绍

Css Parser模块

Binding-DOM与JavascriptCore绑定的功能

JavascriptCore-javascript引擎

API-基本javascript功能

Binding与其它功能绑定的功能,如:DOM,C,JNI

DerviedSource自动产生的代码

PCRE-Perl-CompatibleRegular Expressions

KJS-JavascriptKernel

  .页面的整个处理流程—(简单介绍,详细流程在后面笔记中)

    1).用户输入网址后,FrameLoader::load函数会接收到URL。
    2).把URL请求传给CURL库。

3)CURL发出http请求,得到数据后,传给Loader,开始解析。

4).通过DomBuilder按W3C的html规范生成Dom树

5).如果有javascript,JSEngine就通过ECMA-262标准完善Dom树

6).在生成DOM树的同时,同步生成Render树。

7).解析完后,调用Layout排版

8).Paint出来
  今天学习总结就先到这里,后续继续学习更新。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: