【专业技术】浏览器内核缓冲机制剖析

编者按:缓存能极大提高用户体验,这一点众所周知,下面我们一起来探究Webkit里面的memorycache。

WebKit将资源分为main resouce和sub resource,并提供了相应的cache机制,来提高用户体验。

main resource的cache为pagecache,主要缓存dom和render tree,用于提高history操作(back/forward)的速度。

sub resource的cache则由MemoryCache管理和维护。下面我简要分析下memorycache的主要数据结构。

WebCore提供了使用主存的cache机制,称之为MemoryCache。MemoryCache中存放的数据为decode后的数据。

图12-1是MemoryCache的数据结构图。

图12-1 MemoryCache数据结构图

CachedResource由HashMap统一管理,其key为resource的url,value为CachedResource对象的指针。每一个CachedResource的data由两种内存管理,一种是data小于segment时,使用vector<char>。当data大于segment时,使用m_segment列表。segment的默认大小定义为4096B,即4K。

CachedResource是个双链表,由LRUList结构体维护。m_allResources负责管理系统的所有LRUList。

MemoryCache将CachedResource分为live和dead两类,并维护一个窗口(默认为95%)。dead resource保留在cache中,直到我们要回收dead resource。当我们主动回收dead resource时,并不释放内存。而是把dead resource标注为Purgeable,并由Purgeable Buffer维护。这样做的好处是显而易见的:减少因回收内存而造成的资源重取过程。

QtWebKit中MemoryCache的默认配置为:

QWebSettings::setObjectCacheCapacities((16*1024*1024) / 8, (16*1024*1024) / 8, 16*1024*1024);

访问MemoryCache的接口为WebCore::memoryCache()。

转自:http://m.blog.csdn.net/blog/onecoolx_11109/24415591

原文发布于微信公众号 - 程序员互动联盟(coder_online)

原文发表时间:2015-09-22

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏腾讯云数据库(TencentDB)

CynosDB for PostgreSQL 架构浅析

作者介绍:林锦,腾讯云数据库团队高级工程师,曾任云计算初创公司系统架构师,从事分布式系统研发7年,2017年加入腾讯云,从事NewSQL研发工作,目前主要负责C...

45619
来自专栏瓜大三哥

创建基本时钟周期约束

Xilinx建议把时序约束和物理约束分开来写。(但是必须有一个作为target) 时序约束用于综合和实现,物理约束用于实现。 1时钟周期 2占空比 3相位 ?...

1766
来自专栏IT笔记

分布式与集群有什么区别

一个是3个字,另一个2个字 集群一般被分为三种类型,高可用集群(High-availability (HA) clusters )如RHCS、LifeKeepe...

3504
来自专栏Java工程师日常干货

RocketMQ实战(三):分布式事务关于多Master多Slave的说明Queue in Topic初步认识RocketMQ的核心模块 Order MessageTransaction Messag

由于在之前的博客中已经搭建了双Master,其实多Master多Slave大同小异,因此这里并不会一步步的演示搭建多Master多Slave,而是从思路上,分析...

884
来自专栏CSDN技术头条

详解 NoSQL 数据库的分布式算法

系统的可扩展性是推动NoSQL运动发展的的主要理由,包含了分布式系统协调,故障转移,资源管理和许多其他特性。这么讲使得NoSQL听起来像是一个大筐,什么都能塞进...

1919
来自专栏LinkedBear的个人空间

设计模式笔记(一)——设计模式的引入与三大工厂模式

设计模式(Design Pattern)是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总...

542
来自专栏PHP技术

NoSQL数据库的分布式算法

原文出处: highlyscalable.wordpress.com 译文出处:juliashine 系 统的可扩展性是推动NoSQL运动发展的的主要...

3225
来自专栏鸿的学习笔记

闲话聊聊事务处理(中)

上面提到了multi-object事务,但是要完美的处理multi-object事务并不容易。因为我们必须要面对并发问题导致的bug,而隔离性要求数据系统...

952
来自专栏PHP技术

NoSQL数据库的分布式算法

原文出处: highlyscalable.wordpress.com 译文出处:juliashine 系 统的可扩展性是推动NoSQL运动发展的的主要理由...

2818
来自专栏杨建荣的学习笔记

Greenplum集群故障修复小记

今天有一套环境因为网络调整,结果诺大的Greenplum集群,primary和mirror节点部分有了故障,假设有200个实例,100个segment,...

803

扫描关注云+社区