Lazy Initalization Application
延迟初始化的应用比较广泛,至于它的介绍网上有很多好的文章,这里只作简单的介绍。如果一个对象的某个Field 的获取比较耗时,而且这个Field 不需要预先加载的,我们可以在第一次使用时加载这个Field,我们称这种模式就是延迟初始化模式。
在客户端实现中有很地方可以应用延迟加载模式,这里我只介绍两种:1)View 的延迟初始化;2)Image 的延迟初始化。
首先,我们介绍一下延迟加载模式在View 构造时的应该。一般的系统中,View 的入口为Action,用户可能通过点击Action 打开一个View,从上面的一句话我们可以想到,应该在用户第一次打开的时候去构造View,而不是在Action 被构造的时候或之前去构造View。代码如下:
java 代码
- public interface ViewDescriptor {
-
- public JComponent createView();
-
- public String getLableText();
- }
java 代码
- public class OpenViewAction extends AbstractAction{
-
- private ViewDescriptor descriptor;
-
- private JComponent view;
-
- public OpenViewAction(ViewDescriptor descriptor) {
-
- putValue(NAME, descriptor.getLableText());
- this.descriptor = descriptor;
- }
-
- public void actionPerformed(ActionEvent e) {
- if(view == null)
- view = descriptor.createView();
-
- }
- }
使用上面的模式可以加快系统的启动速度,也加快了用户打开界面的速度(除了第一次,一般的性能测试是按平均打开速度进行统计,而且测试前还有一段的热身时间)。
我们再来讨论一个Image 的延迟初始化,有了上面的介绍,相信Image 的延迟初始化很容易理解。用Java 加载一个很大的图片还是比较耗时的(我没有做过具体的性能测试,但是感觉上,用Java 加载一个4M 的图片不会很快的)。在有些应用中,需要根据对象不同的状态,显示不同的图片,例如:用户输入的校验,用户输入出现错误时我们需要显示红色的图标提醒用户,用户输入出现警告时我们需要显示黄色的图标提醒用户,最典型的例子是Eclipse 中创建Class 的时候,如果我输入非法字符,Wizard 上方出现红色的图标,如果我输入小写开头的Class 时,Wizard 上方出现黄色的图标。像这样的界面,图标应该是在用户第一次出现错误或警告时才去加载相应的图标,而不是在界面打开时去加载。实现的代码和上面的例子很相似,也是抽象一个ImageDescriptor 接口用于延迟创建Image,具体代码如下:
java 代码
- public interface ImageDescriptor {
- public Image createImage();
- }
上面的两个示例只是简单的介绍了延迟初始,事实上不同的系统中会有很多这样的应用,由于我接触领域相对较小,只能介绍这么多了。
这些应用主要参考了Spring Rich Client 和Eclipse 的原码。
分享到:
相关推荐
Lazy
《jQuery LazyLoad 2.x API详解与应用实践》 在当今网页开发中,为了提高页面加载速度和用户体验,"懒加载"(Lazy Load)技术变得越来越重要。jQuery LazyLoad插件是一个广泛使用的解决方案,它允许图片、iframe等...
在.NET框架中,C#语言提供了许多特性来帮助开发者优化应用程序的性能,其中之一就是`Lazy<T>`类。这个类主要用于实现延迟加载(Lazy Loading),它允许我们推迟对象的初始化,直到真正需要使用该对象时才会执行初始...
标题提到的"LazyUI-dependency"表明这是一个关于懒加载用户界面(LazyUI)的依赖集合,可能是为了帮助开发者更方便地集成到自己的项目中,尤其是对于那些不熟悉或者不喜欢使用Maven进行依赖管理的开发者。...
jQuery_lazyload是一个非常实用的JavaScript库,用于优化网页性能,特别是在处理大量图片或者内容时。这个插件的主要目的是延迟加载,即在用户滚动到页面的特定部分时才加载那些可视区域以外的内容,从而减少初次...
**懒加载技术与lazyload.js详解** 懒加载(Lazy Load)是一种优化网页性能的技术,它主要应用于图片或视频等大容量资源的加载。在网页初次加载时,仅加载视口内的内容,当用户滚动页面或者靠近某个元素时,再加载...
懒加载(Lazy Load)是一种网页优化技术,主要应用于图片、视频等大容量媒体资源的加载。它的核心思想是延迟加载,即在用户滚动页面时,只加载可视区域内的元素,而不是一次性加载整个页面的所有资源。这极大地提高...
**jQuery Lazyload 图片加载技术详解** 在网页设计中,图片是重要的元素之一,但大量图片的预加载可能会拖慢页面的加载速度,影响用户体验。为了解决这一问题,jQuery 提供了一个插件——jQuery Lazyload,它允许...
《jQuery.Lazyload.js:优化网页加载速度与用户体验的艺术》 在现代网页设计中,页面加载速度和用户体验是至关重要的因素。jQuery.Lazyload.js是一个高效实用的JavaScript插件,它能够显著提升网页加载速度,同时...
Magento LazyLoad 插件是针对Magento电子商务平台设计的一款性能优化工具。它的主要功能是实现图片的延迟加载(Lazy Load),以此提升网站的加载速度和用户体验。在网页浏览时,传统方式下所有图片会一次性全部加载...
图片延迟加载(Lazy Load)是一种优化网页性能的技术,主要用于处理大量图片或多媒体资源的加载。在网页设计中,当用户滚动页面时,只有进入视口的图片才会开始加载,而那些还未显示出来的图片则会暂时保持占位符...
**图片懒加载技术详解与"lazyload"使用案例** 在现代网页设计中,为了提高页面加载速度和用户体验,"图片懒加载"(Lazy Loading)技术得到了广泛应用。它是一种优化策略,仅在用户滚动到图像所在区域时才加载图片,...
懒加载(Lazy Load)是一种优化网页性能的技术,它允许网页在初始加载时只加载可视区域内的内容,而将非可视区域的内容(如图片、视频等)延后加载,直到用户滚动到相应位置时才开始加载。jQuery Lazy Load Plugin ...
**jQuery LazyLoad 知识详解** 在网页设计与开发中,优化用户体验和页面加载速度是一项至关重要的任务。jQuery 的 LazyLoad 插件提供了一种高效的方法来处理这个问题,特别是对于那些图片众多、流量消耗大的网站而...
jQuery.lazyload 是一个非常流行的JavaScript插件,专用于优化网页性能,通过实现图片的懒加载技术。这个插件的核心理念是延迟非视口内的图片加载,直到用户滚动页面并接近这些图片时才进行加载。这样可以显著减少...
在Web开发中,JQuery.LazyLoad是一款非常流行的实现动态加载的插件。它基于JavaScript库jQuery,允许开发者轻松地将延迟加载功能添加到图片或其他HTML元素上。JQuery.LazyLoad的工作原理是监控页面滚动事件,当元素...
**标题:“lazyload-JavaScript”** 在网页开发中,图片懒加载(Lazy Load)是一种优化用户体验和提高页面加载速度的技术。"lazyload"是指在JavaScript中实现的延迟加载策略,它只在用户滚动到视口附近的图片时才...
Lazyload是通过延迟加载来实现按需加载,达到节省资源,加快浏览速度的目的。 网上也有不少类似的效果,这个Lazyload主要特点是: 支持使用window(窗口)或元素作为容器对象; 对静态(位置大小不变)元素做了大量...
**jQuery LazyLoad 图片懒加载实例** 在网页设计中,图片加载是影响页面性能的关键因素。当页面包含大量图片时,一次性加载所有图片可能会导致页面加载速度变慢,用户体验下降。为了解决这一问题,我们可以使用`...