Enterprise Library 2.0 Hands On Lab 翻译(11):缓存应用程序块(三)

简介:
练习3:实现后台缓存
该练习将示范如何实现后台加载。
 
第一步
打开EmployeeBrowser.sln 项目,默认的安装路径应该为C:\Program Files\Microsoft Enterprise Library January 2006\labs\cs\Caching\exercises\ex03\begin,并编译。
 
第二步 实现后台加载
1 .在解决方案管理器中选择EmployeeServices.cs文件,选择View | Code菜单命令,添加如下两个方法,它们将实现在后台加载缓存。
//  TODO: PopulateCache & BeginBackgroundLoad

private   static   void  PopulateCache()

{

    
byte[] photoData = null;

    EmployeesDataSet dsEmployees 
= GetContactDetails();

    
if (dsEmployees == null)

        
return;

    CacheManager cache 
= CacheFactory.GetCacheManager();

    
foreach (EmployeesDataSet.EmployeesRow employee in dsEmployees.Employees)

    
{

        
if (!cache.Contains(employee.EmployeeID.ToString()))

        
{

            EmployeeDataProvider dataProvider 
= new EmployeeDataProvider();

            photoData 
= dataProvider.GetEmployeePhotoData(employee.EmployeeID);

            cache.Add(employee.EmployeeID.ToString(), photoData);

        }


    }


}


private   delegate   void  PopulateCacheDelegate();

public   static   void  BeginBackgroundLoad()

{

    
if (!ConnectionManager.IsOnline)

        
return;


    PopulateCacheDelegate mi 
= new PopulateCacheDelegate(PopulateCache);

    mi.BeginInvoke(
nullnull);

}
BeginBackgroundLoad 方法使用一个委托在后台线程开始PopulateCache方法,它将会被.NET工作线程处理。
2 .选择MainForm.cs文件,选择View | Code菜单命令,在方法MainForm_Load中加入如下代码开始后台工作。
private   void  MainForm_Load( object  sender, EventArgs e)

{

    
this.ToolStripLabel1.Text = ConnectionManager.StatusText;


    
// Load data into the 'EmployeesDataSet'.

    EmployeesDataSet tempDataset 
= EmployeeService.GetContactDetails(); 

    
if (tempDataset != null)

        
this.EmployeesDataSet.Merge(tempDataset);

    
// TODO: Start loading cache in the background

    EmployeeService.BeginBackgroundLoad();

}
 
第三步 运行应用程序
1 .选择Debug | Start Without Debugging菜单命令运行应用程序。
不要浏览任何雇员数据,在等待大概10秒后退出应用程序。如果应用程序在线它将尝试后台加载雇员照片,缓存存储在物理存储位置上,即持久缓存,但是与前一个练习使用了不同的PartitionName
2 .在解决方案管理器中选择ConnectionManager.cs,选择View | Code菜单命令,在下面的代码中修改IsOnline属性的值。
static   public   bool  IsOnline

{
    
get return false; }
}
3 .选择Debug | Start Without Debugging菜单命令运行应用程序。现在应用程序不再连接数据库处于离线状态,所有的雇员信息已经照片已经被缓存。
 
更多Enterprise Library的文章请参考《Enterprise Library系列文章












本文转自lihuijun51CTO博客,原文链接:  http://blog.51cto.com/terrylee/67642 ,如需转载请自行联系原作者
相关文章
|
6月前
|
缓存 Java 数据库
优化您的Spring应用程序:缓存注解的精要指南
优化您的Spring应用程序:缓存注解的精要指南
106 0
|
6月前
|
缓存 监控 中间件
中间件Cache-Aside策略应用程序直接与缓存和数据库进行交互
【5月更文挑战第8天】中间件Cache-Aside策略应用程序直接与缓存和数据库进行交互
76 4
|
6月前
|
存储 缓存 移动开发
HTML5 应用程序缓存
HTML5的离线缓存(Application Cache)允许网页存储资源以实现离线访问。通过manifest文件指定缓存内容和更新规则,比如列出要缓存的HTML、CSS、JS和图片。在HTML中引用manifest文件后,浏览器会根据文件变化更新缓存。但要注意,应用缓存不自动更新,需手动修改manifest触发,并且现代Web开发更多使用服务工作者(Service Workers)替代,以获得更优的离线体验和更新策略。
|
存储 缓存 数据库
极速Python编程:利用缓存加速你的应用程序
在软件开发中,缓存是一种常用的技术,用于提高系统性能和响应速度。Python提供了多种缓存技术和库,使我们能够轻松地实现缓存功能。本文将带您从入门到精通,逐步介绍Python中的缓存使用方法,并提供实例演示。
297 0
|
存储 缓存 移动开发
前端开发面试题—HTML5应用程序缓存 (离线存储)
今天分享一下我遇到的前端面试题,什么是HTML5应用程序缓存 (离线存储) ?
254 0
前端开发面试题—HTML5应用程序缓存 (离线存储)
|
缓存 前端开发 JavaScript
前端培训-中级阶段(23)- Manifest ApplicationCache应用程序缓存(2019-10-31期)
前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。
173 0
前端培训-中级阶段(23)- Manifest  ApplicationCache应用程序缓存(2019-10-31期)
|
缓存 Java
面经 - 【多线程】在Java中Lock接口比synchronized块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?
面经 - 【多线程】在Java中Lock接口比synchronized块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?
437 0
|
缓存 区块链 Windows
应用程序图标设置 系统图标缓存问题
应用程序图标设置 系统图标缓存问题
194 0
|
1月前
|
存储 缓存 NoSQL
数据的存储--Redis缓存存储(一)
数据的存储--Redis缓存存储(一)
|
1月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
67 6

热门文章

最新文章