`
wangyonghe
  • 浏览: 43270 次
社区版块
存档分类
最新评论

[原创]Lazy Initalization Application

阅读更多
 Lazy Initalization Application

        延迟初始化的应用比较广泛,至于它的介绍网上有很多好的文章,这里只作简单的介绍。如果一个对象的某个Field 的获取比较耗时,而且这个Field 不需要预先加载的,我们可以在第一次使用时加载这个Field,我们称这种模式就是延迟初始化模式。

    在客户端实现中有很地方可以应用延迟加载模式,这里我只介绍两种:1)View 的延迟初始化;2)Image 的延迟初始化。

    首先,我们介绍一下延迟加载模式在View 构造时的应该。一般的系统中,View 的入口为Action,用户可能通过点击Action 打开一个View,从上面的一句话我们可以想到,应该在用户第一次打开的时候去构造View,而不是在Action 被构造的时候或之前去构造View。代码如下:

java 代码
  1. public interface ViewDescriptor {   
  2.   
  3.     public JComponent createView();   
  4.        
  5.     public String getLableText();   
  6. }   
java 代码
  1. public class OpenViewAction extends AbstractAction{   
  2.   
  3.     private ViewDescriptor descriptor;   
  4.        
  5.     private JComponent view;   
  6.   
  7.     public OpenViewAction(ViewDescriptor descriptor) {   
  8.         //Check the descriptor   
  9.         putValue(NAME, descriptor.getLableText());   
  10.         this.descriptor = descriptor;   
  11.     }   
  12.        
  13.     public void actionPerformed(ActionEvent e) {   
  14.         if(view == null)   
  15.             view = descriptor.createView();   
  16.         //Show view and bind data.   
  17.     }   
  18. }   

    使用上面的模式可以加快系统的启动速度,也加快了用户打开界面的速度(除了第一次,一般的性能测试是按平均打开速度进行统计,而且测试前还有一段的热身时间)。

    我们再来讨论一个Image 的延迟初始化,有了上面的介绍,相信Image 的延迟初始化很容易理解。用Java 加载一个很大的图片还是比较耗时的(我没有做过具体的性能测试,但是感觉上,用Java 加载一个4M 的图片不会很快的)。在有些应用中,需要根据对象不同的状态,显示不同的图片,例如:用户输入的校验,用户输入出现错误时我们需要显示红色的图标提醒用户,用户输入出现警告时我们需要显示黄色的图标提醒用户,最典型的例子是Eclipse 中创建Class 的时候,如果我输入非法字符,Wizard 上方出现红色的图标,如果我输入小写开头的Class 时,Wizard 上方出现黄色的图标。像这样的界面,图标应该是在用户第一次出现错误或警告时才去加载相应的图标,而不是在界面打开时去加载。实现的代码和上面的例子很相似,也是抽象一个ImageDescriptor 接口用于延迟创建Image,具体代码如下:

java 代码
  1. public interface ImageDescriptor {   
  2.     public Image createImage();   
  3. }   

    上面的两个示例只是简单的介绍了延迟初始,事实上不同的系统中会有很多这样的应用,由于我接触领域相对较小,只能介绍这么多了。

    这些应用主要参考了Spring Rich Client 和Eclipse 的原码。

分享到:
评论

相关推荐

    Lazy

    Lazy

    lazyload-2.x.zip

    《jQuery LazyLoad 2.x API详解与应用实践》 在当今网页开发中,为了提高页面加载速度和用户体验,"懒加载"(Lazy Load)技术变得越来越重要。jQuery LazyLoad插件是一个广泛使用的解决方案,它允许图片、iframe等...

    C#使用Lazy延迟加载

    在.NET框架中,C#语言提供了许多特性来帮助开发者优化应用程序的性能,其中之一就是`Lazy<T>`类。这个类主要用于实现延迟加载(Lazy Loading),它允许我们推迟对象的初始化,直到真正需要使用该对象时才会执行初始...

    LazyUI-dependency

    标题提到的"LazyUI-dependency"表明这是一个关于懒加载用户界面(LazyUI)的依赖集合,可能是为了帮助开发者更方便地集成到自己的项目中,尤其是对于那些不熟悉或者不喜欢使用Maven进行依赖管理的开发者。...

    jQuery_lazyload

    jQuery_lazyload是一个非常实用的JavaScript库,用于优化网页性能,特别是在处理大量图片或者内容时。这个插件的主要目的是延迟加载,即在用户滚动到页面的特定部分时才加载那些可视区域以外的内容,从而减少初次...

    lazyload.js演示页面

    **懒加载技术与lazyload.js详解** 懒加载(Lazy Load)是一种优化网页性能的技术,它主要应用于图片或视频等大容量资源的加载。在网页初次加载时,仅加载视口内的内容,当用户滚动页面或者靠近某个元素时,再加载...

    懒加载lazyload

    懒加载(Lazy Load)是一种网页优化技术,主要应用于图片、视频等大容量媒体资源的加载。它的核心思想是延迟加载,即在用户滚动页面时,只加载可视区域内的元素,而不是一次性加载整个页面的所有资源。这极大地提高...

    JQuery Lazyload加载图片实例

    **jQuery Lazyload 图片加载技术详解** 在网页设计中,图片是重要的元素之一,但大量图片的预加载可能会拖慢页面的加载速度,影响用户体验。为了解决这一问题,jQuery 提供了一个插件——jQuery Lazyload,它允许...

    jquery.lazyload.js

    《jQuery.Lazyload.js:优化网页加载速度与用户体验的艺术》 在现代网页设计中,页面加载速度和用户体验是至关重要的因素。jQuery.Lazyload.js是一个高效实用的JavaScript插件,它能够显著提升网页加载速度,同时...

    magento lazyload插件

    Magento LazyLoad 插件是针对Magento电子商务平台设计的一款性能优化工具。它的主要功能是实现图片的延迟加载(Lazy Load),以此提升网站的加载速度和用户体验。在网页浏览时,传统方式下所有图片会一次性全部加载...

    图片延迟加载 lazyload

    图片延迟加载(Lazy Load)是一种优化网页性能的技术,主要用于处理大量图片或多媒体资源的加载。在网页设计中,当用户滚动页面时,只有进入视口的图片才会开始加载,而那些还未显示出来的图片则会暂时保持占位符...

    lazyload使用案例及DEMO

    **图片懒加载技术详解与"lazyload"使用案例** 在现代网页设计中,为了提高页面加载速度和用户体验,"图片懒加载"(Lazy Loading)技术得到了广泛应用。它是一种优化策略,仅在用户滚动到图像所在区域时才加载图片,...

    Lazy Load Plugin for jQuery demo

    懒加载(Lazy Load)是一种优化网页性能的技术,它允许网页在初始加载时只加载可视区域内的内容,而将非可视区域的内容(如图片、视频等)延后加载,直到用户滚动到相应位置时才开始加载。jQuery Lazy Load Plugin ...

    jquery lazyload延时加载

    **jQuery LazyLoad 知识详解** 在网页设计与开发中,优化用户体验和页面加载速度是一项至关重要的任务。jQuery 的 LazyLoad 插件提供了一种高效的方法来处理这个问题,特别是对于那些图片众多、流量消耗大的网站而...

    jQuery.lazyload-1.7.2

    jQuery.lazyload 是一个非常流行的JavaScript插件,专用于优化网页性能,通过实现图片的懒加载技术。这个插件的核心理念是延迟非视口内的图片加载,直到用户滚动页面并接近这些图片时才进行加载。这样可以显著减少...

    动态加载的图片LazyLoad

    在Web开发中,JQuery.LazyLoad是一款非常流行的实现动态加载的插件。它基于JavaScript库jQuery,允许开发者轻松地将延迟加载功能添加到图片或其他HTML元素上。JQuery.LazyLoad的工作原理是监控页面滚动事件,当元素...

    lazyload-JavaScript

    **标题:“lazyload-JavaScript”** 在网页开发中,图片懒加载(Lazy Load)是一种优化用户体验和提高页面加载速度的技术。"lazyload"是指在JavaScript中实现的延迟加载策略,它只在用户滚动到视口附近的图片时才...

    lazyload延迟加载

    Lazyload是通过延迟加载来实现按需加载,达到节省资源,加快浏览速度的目的。 网上也有不少类似的效果,这个Lazyload主要特点是: 支持使用window(窗口)或元素作为容器对象; 对静态(位置大小不变)元素做了大量...

    JQuery LazyLoad 图片懒加载实例

    **jQuery LazyLoad 图片懒加载实例** 在网页设计中,图片加载是影响页面性能的关键因素。当页面包含大量图片时,一次性加载所有图片可能会导致页面加载速度变慢,用户体验下降。为了解决这一问题,我们可以使用`...

Global site tag (gtag.js) - Google Analytics