最近,InfoQ中文站报道了Web 2.0应用客户端性能问题十大根源,获得了读者朋友的关注。那么,如何从浏览器角度剖析性能问题呢?微软IE开发团队性能主管Jason Weber在一篇博文中介绍了IE浏览器的各个子系统,并通过实验数据展示了不同网站对浏览器子系统的性能影响和权重,InfoQ中文站对相关内容做了整理,希望对浏览器开发人员和Web应用开发人员有所帮助。
Jason Weber指出,所有现代浏览器从概念上讲都是类似的。以IE为例,它由11个核心子系统组成:
图1. IE子系统(来源:IE博客,下同)
Networking——负责客户端与服务器端的所有通信,包括Web内容的本地缓存。它通常受制于用户网络环境的性能。
HTML——负责解析HTML文档并创建HTML结构化数据等。
CSS——负责解析CSS并创建CSS结构化数据。
Collections——存储和访问HTML文档中的元数据,如文档头部的描述信息等。
JavaScript—— 执行JavaScript代码,它也是最为人所知的子系统。
Marshaling——因为大多数JavaScript引擎没有直接集成到浏览器中,所以浏览器和JavaScript引擎之间存在一个通信层,这就是marshaling子系统。
Native OM——JavaScript通过DOM API与HTML文档交互,提供这些API的就是Native OM系统,能够访问和处理文档。
Formatting——负责将style应用到文档中。
Block Building——负责构建显示给用户的矩形块(CSS基于块布局),包括块尺寸等。
Layout——负责布局经过Formatting和Block Building子系统处理后的Web内容和块结构。
Rendering——负责把最终内容渲染给用户。
为了分析不同网站对浏览器子系统的各种性能影响和权重,IE性能团队选取了两种类型的网站进行实验。由于Networking子系统的性能与客户的环境息息相关,所以不将其权重纳入评估结果中。
新闻网站
采用IE 8访问全球五大新闻网站的首页,性能结果如图2所示:
图 2. IE 8子系统针对5大新闻网站的性能结果
由图2可以看出,虽然同为新闻网站,但是由于Web开发人员对网站性能的关注和优化程度不同,IE 8子系统对5个首页的性能反馈都不一样。1号网站的主要性能消耗在JavaScript子系统上,2号网站的重头戏则是Marshaling子系统。3号网站显然遵循了性能最佳实践经验,所以消耗时间最短;而4号网站则是反面典型,加载时间达到了3.7秒。
如果把这5大新闻网站对IE 8子系统的影响权重综合在一起,就可以得到针对新闻网站的子系统性能影响权重,如图3所示:
图 3. 新闻类网站对IE 8子系统的性能影响权重
上面这张图对于Web开发人员特别是新闻类网站工程师很有参考价值,排在前三位的子系统分别是JavaScript (29%)、Marshalling(18%)和Rendering (17%)。
AJAX网站
采用IE 8访问全球AJAX用户体验最丰富的25家网站(包括Facebook、Gmail和Hotmail等),性能结果如图4所示:
图 4. AJAX类网站对IE 8子系统的性能影响权重
与新闻类网站相比,某些子系统如HTML、CSS和JavaScript权重相对较轻,而另外一些子系统如Formatting、Layout、Block Building和Rendering(31%)则比较重要。乍一看,这种结果可能有些意外。不过,Jason Weber分析了原因:
当JavaScript代码执行时,浏览器需要利用几乎全部子系统来配合相应的变化并最终显示给用户,而这些过程的性能消耗通常要比执行JavaScript代码本身要昂贵得多。
Jason Weber最后指出,分析IE浏览器子系统性能权重的目的在于确保让IE 9或者更新版本在现实世界中运行速度更快。在过去几个月里,IE开发团队针对上面的性能实验结果采取了若干子系统的性能改进,包括硬件加速渲染、编译JavaScript和原生内部集成JavaScript等。
对于浏览器子系统的性能权重分析具有很高的参考价值,一方面可以帮助浏览器开发人员了解现实世界对自身产品的反馈,评估各个子系统的功能优先级;一方面能够帮助Web开发人员清楚其应用对浏览器的性能压力,采取合适的优化调整。
分享到:
相关推荐
"新版IE浏览器源代码" 提供了一个深入了解浏览器内部工作原理的机会,特别是对于那些对前端开发、浏览器内核或者系统级编程感兴趣的开发者而言。这个资源可能包含了构建和修改IE浏览器功能的原始代码。 描述中提到...
本文将详细介绍一款专为IE浏览器设计的JS调试插件及其使用方法。 首先,我们要理解为什么IE浏览器需要特定的JS调试工具。与其他现代浏览器如Chrome、Firefox相比,IE在处理JavaScript时可能有不同的行为。例如,它...
标签中的“IE浏览器”是指微软的Internet Explorer,它是Windows操作系统早期默认的网页浏览器。“网页监控”指的是对用户在浏览器中进行的网络活动进行跟踪和分析。“VC”则代表Visual C++,这是一个广泛使用的...
在IE浏览器的上下文中,挂接可能意味着创建一个插件或组件,该插件能在浏览器运行时提供额外的功能,如网页内容分析、广告拦截或者自定义浏览体验。 易语言挂接到IE浏览器,涉及到的主要知识点包括: 1. **易语言...
《C#版“我的IE浏览器”深度解析》 在编程领域,C#是一种广泛应用的面向对象的编程语言,尤其在Windows应用开发中占有重要地位。本项目“我的IE浏览器”正是利用C#语言构建的一个模仿IE6浏览器的程序,旨在为开发者...
### IE浏览器经典故障大全 #### 一、IE页面无法正常加载及错误提示处理方法 ...由于IE浏览器版本众多,不同的系统环境下可能出现的问题也不尽相同,因此在实际操作过程中还需要结合具体情况进行针对性的调整。
在探讨IE浏览器漏洞挖掘技术的过程中,本文首先指出软件漏洞对用户隐私和利益造成严重威胁,尤其在浏览器领域中,IE浏览器由于其广泛使用和市场份额,其安全问题显得尤为重要。基于这种背景下,IE漏洞的挖掘显得尤为...
以上是针对IE浏览器常见故障的分析和解决策略,这些技巧可以帮助用户自行解决IE浏览器在使用过程中遇到的问题,提高浏览体验。在处理这类问题时,确保备份注册表或系统数据,以防止不必要的数据丢失。同时,保持...
标题中的“我的ie浏览器源程序”表明这是一个与Internet Explorer(IE)浏览器相关的源代码项目,可能是一个个人开发的简易版本,用于学习或扩展浏览器功能。IE浏览器是微软公司早期推出的一款广泛使用的网络浏览...
IE浏览器开发人员工具不仅为开发者提供了强大的网页调试和分析手段,还为普通用户提供了一些实用的功能,如查看源代码、管理缓存、测量网页元素、颜色选取以及浏览器模式切换。这些“小工具”使得IE浏览器不仅仅是一...
COM ATL SHELL EXTENSION是一种技术,它允许开发者向Windows操作系统中的文件或文件夹在资源管理器或者IE浏览器中添加自定义的右键快捷菜单项。这个压缩包包含了一系列的源代码文件和资源文件,用于创建这样一个扩展...
在提供的文件"AnalysisWMFilters_Pranam.pdf"中,很可能是详细介绍了权重介质滤波器的理论背景、MATLAB实现步骤以及性能分析的结果。这份文档可能包含了实验设计、滤波器性能比较、参数优化等方面的内容,对于深入...
学习和分析【IE恢复器 Delphi源码】不仅可以提高对Delphi编程的理解,还可以深入探究IE浏览器的工作机制,以及如何应对网络威胁。对于那些想要开发类似工具或者提升网络安全防护能力的程序员来说,这是一个非常有...
### 多目标决策中的权重敏感性分析 #### 一、引言 在多目标决策问题中,确定不同目标之间的相对重要性是一项至关重要的任务。为了反映这种重要性,通常会通过对各个目标赋予不同的权重来实现。然而,在实际的决策...
在描述中提到的 "还可以,开发web程序的能用到",意味着Drip虽然可能不是唯一或最全面的解决方案,但它对于Web开发者来说是一个有价值的工具,尤其在处理IE浏览器兼容性和性能优化时。IE内存泄漏可能会导致Web应用...
层次分析求权重,。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。...
《AHP层次分析法计算权重、特征值、特征向量》 在数据分析和决策支持领域,层次分析法(Analytic Hierarchy Process,简称AHP)是一种广泛应用的多准则决策分析方法,由萨蒂教授提出。它通过将复杂问题分解为多层次...
本文件描叙了教务管理系统之子系统是设计以及如果实现该系统,具体详细的介绍了排课系统的需求分析和总体设计。