WebKit内核学习之二

来源:互联网 发布:每日工作计划软件 编辑:程序博客网 时间:2024/04/30 08:49

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

  在学习WebKit初期,个人认为要大致了解源码的框架结构,知道大的框架目录大致什么作用。

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


1). WebCore

2). WebKit

3). JavaScriptCore


WebCore排版引擎核心,WebCore包含主要以下模块:Loader,Parser(DOM,Render), Layout,Paint

WebKit:移植层,主要包含:GUIFileSystem, ThreadText,图片编解码等与平台相关的函数。

JavaScriptCoreJS虚拟机,相对独立,主要用于操作DOMDOMW3C定义的规范,主要用于定义外部可以操作的浏览器内核的接口,而webcore必须实现DOM规范。(具体的DOM规范可以查w3c.)


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

Webkit平台相关

  1. CURL网络库

  2. libPng,LibJpeg图形处理相关

  3. sqlite小型关系数据库

WebCore核心

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

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

  3. DOM :DOM节点与Render节点创建,形成DOM

  4. RenderRender树介绍,RenderBox

  5. Layout:排版介绍

  6. Css Parser模块

  7. Binding-DOMJavascriptCore绑定的功能

JavascriptCore-javascript引擎

  1. API-基本javascript功能

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

  3. DerviedSource自动产生的代码

  4. PCRE-Perl-CompatibleRegular Expressions

  5. KJS-JavascriptKernel


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

        1).用户输入网址后,FrameLoader::load函数会接收到URL

        2).URL请求传给CURL库。

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

4).通过DomBuilderW3Chtml规范生成Dom

5).如果有javascriptJSEngine就通过ECMA-262标准完善Dom

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

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

8).Paint出来

  今天学习总结就先到这里,后续继续学习更新。

0 0
原创粉丝点击