延迟加载(lazy loading) 设计模式是为了避免一些无谓的性能开销而提出来的,所谓延迟加载就是当在真正需要数据(读取属性值)的时候,才真正执行数据加载操作.
有效使用它可以大大提高系统性能.
为了便于理解, 我们来建立一个场景, 假设我们要构造一个Hero(英雄) 类, 每个Hero 有自己的名字和(SpecialSkill)特殊技能.
建模
这是一种建立的方法:
public class Hero
{
public string FullName { get; set; }
public string Name { get; set; }
public SpecialSkill Skill{ get; set; }
public Hero(string name)
{
Name = name;
FullName = "Super " + name;
Skill = new SpecialSkill(name);
}
}
public class SpecialSkill
{
public int Power { get; set; }
public string SkillName { get; set; }
public int StrengthSpent { get; set; }
public SpecialSkill(string name)
{
Console.WriteLine("loading special skill .....");
Power = name.Length;
StrengthSpent = name.Length * 3;
SkillName = name + " Blazing";
Console.WriteLine(SkillName + ",... this's what makes a legend!");
}
}
class Program
{
static void Main(string[] args)
{
Hero hero = new Hero("wukong");
Console.WriteLine("\n\n.......................Press Enter to continue.......................\n\n");
Console.Read();
Console.WriteLine("Hero's special skill: " + hero.Skill.SkillName);
Console.Read();
Console.Read();
}
}
运行程序后输出如下, 这个例子非常的容易理解, 结果也是显然的.
它的缺点是, 当运行Hero 构造函数的时候, SpecialSkill 的所有属性都已经加载了. 如果我们只想获取这个Hero 的FullName, 我们也加载了SpecialSkill 所有值.
属性的加载延迟
在没有Lazy<T> 以前我们可以这样做:
public class Hero
{
public string FullName { get; set; }
public string Name { get; set; }
private SpecialSkill skill;
public SpecialSkill Skill
{
get { return skill ?? (skill = new SpecialSkill(Name)); }
}
public Hero(string name)
{
Name = name;
FullName = "Super " + name;
}
}
即: 修改属性SpecialSkill的加载方法. 那么当我们再运行程序时, 得到的输出就是:
非常好! 这就是我们要的效果, 这样可以让系统更加的有效率.
Lazy<T>
当net framework 引入了Lazy<T> 类后, 我们也可以使用它来实现:
public class Hero
{
public string FullName { get; set; }
public string Name { get; set; }
private readonly Lazy<SpecialSkill> skill;
public SpecialSkill Skill
{
get { return skill.Value; }
}
public Hero(string name)
{
Name = name;
FullName = "Super " + name;
skill = new Lazy<SpecialSkill>(() => new SpecialSkill(name));
}
}
Lazy<T>提供对延迟初始化的支持。而 Lazy<T> 中的一个属性 Value, 则是获取当前 Lazy<T> 实例的延迟初始化值。
Lazy<T>的优势
那么既然我们已经可以用属性缓存的方法实现, 为什么还要引入Lazy<T> ?
至少Lazy<T> 有以下几点优势:
- 它具有 LazyThreadSafetyMode, 但是我们一般不使用它, 除非是很关键的情况下(在此略去181个字)
- 它使属性的定义行更加简单
- 从语义上来讲, 它更加明确, 更加具有可读性
- 它允许null为有效值
分享到:
相关推荐
图片延迟加载是一种优化网页性能的技术,它通过在用户滚动页面时才加载可见区域内...总的来说,jQuery Lazyload 是一个强大且易用的图片延迟加载解决方案,通过合理配置和使用,可以有效地改善网页性能,提高用户体验。
在实际开发中,为了提高性能和减少内存消耗,MyBatis提供了延迟加载(Lazy Loading)功能。延迟加载允许我们在真正需要数据时才去加载关联的对象,而不是在查询主对象时一次性加载所有关联数据。 标题中的“mybatis...
图片延迟加载是一种优化网页性能的技术,它不立即加载页面上的所有图片,而是只加载当前视口内的图片。当用户滚动页面时,原本隐藏在视口之外的图片会逐渐进入视野,此时才进行加载。这样可以显著减少初始页面加载...
综上所述,图片懒加载是前端开发中一种有效的性能优化手段,通过合理运用,我们可以提高网站性能,提升用户满意度。在实际开发中,应根据项目需求和用户群体特点,灵活选择并定制合适的懒加载策略。
它是一种高效的图片延迟加载插件,允许我们在用户滚动到图片所在位置时才开始加载,从而显著提高网页的加载速度。 **1. jQuery LazyLoad.js 的工作原理** jQuery LazyLoad.js 的核心思想是“按需加载”。它监控...
同时,需要注意的是,虽然延迟加载能提高加载速度,但过度依赖可能会对SEO产生负面影响,因为搜索引擎爬虫可能无法抓取到延迟加载的内容。因此,在实际应用中需要找到平衡,兼顾用户体验和搜索引擎优化。
图片延时加载(也称为懒加载)则只在图片进入浏览器视口时才开始加载,这样可以显著提高页面的加载速度,节省用户的流量。 `lazyload`框架的工作原理主要包括以下几个步骤: 1. **标记待延迟加载的图片**:首先,...
因此,合理地管理 SqlSession 可以提高性能。 2. **二级缓存(Global Cache)**:二级缓存是 Mapper(namespace)级别的缓存,它可以跨 SqlSession 共享数据。开启二级缓存需要在 MyBatis 配置文件中设置 `<cache/>...
图片延迟加载是一种优化网页性能的技术,它通过只加载视口内的图片来减少页面初始化时的数据传输量,提高页面加载速度,提升用户体验。在本场景中,我们关注的是使用jQuery库实现这一功能的jQuery.lazyload插件。 ...
3. **优化技巧**:为了提高性能,可以使用Intersection Observer API,它提供了一种更有效的方式监听元素何时进入或离开视口。此外,还可以使用Web Workers进行后台图片预加载,或者利用Intersection Observer的`...
其中,延迟加载(Lazy Loading)是一种非常重要的特性,它可以显著提高应用程序的性能和响应速度。本文将对Hibernate中的延迟加载技术进行深入剖析,帮助读者更好地理解和运用这项技术。 #### 二、基本概念 ##### ...
GridPanel是ExtJs中一个非常重要的组件,它用于展示表格数据,而延时加载则是一种优化大量数据处理的技术,可以显著提高用户界面的响应速度。 1. **ExtJs GridPanel**: GridPanel是ExtJs中的核心组件之一,它提供...
网页图片延迟加载,也称为懒加载(Lazy Loading),是一种优化网页性能的技术,它允许网页在初始加载时只加载可见区域的图片,而将其他非可视区域的图片推迟到用户滚动到相应位置时再加载。这种技术可以显著减少网页...
在大型项目中,由于数据量庞大,为了提高性能和减少数据库的负载,Hibernate引入了“延迟加载”(Lazy Loading)机制。标题和描述提到的“hibernate延迟加载解决”主要涉及如何理解和解决与之相关的常见问题。 **1....
综上所述,延迟加载是提升网页性能的有效手段,通过JavaScript和jQuery,我们可以轻松地实现页面和图片的延迟加载,从而提高用户访问体验。提供的压缩包文件JqueryLazyLoad.rar和LazyLoad.rar可能包含了实现这些功能...
图片延迟加载,也称为懒加载,是一种优化网页性能的技术。它使得图片在用户滚动到可视区域时才开始加载,而不是在页面初次加载时一次性加载所有图片。这样可以显著减少初始加载时间,提高用户体验,特别是对于移动...
延时加载(Lazy Loading)是一种设计模式,主要用于改善应用性能。在JavaScript中,它意味着不立即加载所有代码和数据,而是等到用户触发特定操作或组件需要时才进行加载。这可以显著提高应用程序的启动速度,尤其...
在JavaScript的世界里,延迟加载(Lazy Loading)是一种优化网页性能的技术,它允许我们仅在真正需要时才加载资源,如图片、脚本或视频。这种技术可以显著减少初始页面加载时间,提高用户体验,并减少服务器压力。...
5. **优化**:为了进一步提高性能,可以采用预加载策略,对即将进入视口的资源提前加载,或者利用Intersection Observer API等现代浏览器特性来更精确地跟踪元素进入视口的状态。 6. **兼容性考虑**:在编写延迟...
图片延时加载(Lazy Loading)是一种优化网页性能的技术,它主要应用于处理大量图片的网页,目的是提高页面加载速度,减少用户等待时间,并节省网络带宽。在这个“图片延时加载demo”中,我们将深入探讨这一技术的...