欧美日韩精品在线,国内精品久久久久久久久,一级毛片恃级毛片直播,清纯唯美亚洲综合欧美色

依賴注入機(jī)制及IoC的設(shè)計(jì)與實(shí)現(xiàn)_.Net教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:近期的幾個(gè)ASP.NET開發(fā)經(jīng)驗(yàn)總結(jié)和收集
一:頁面中Page_Load事件 和 Page.IsPostBack執(zhí)行兩次的原因. 原因一: 當(dāng)<%@Page....中沒有AutoEventWireup定義時(shí)會(huì)導(dǎo)致Page_Load執(zhí)行兩次,如果有定義,且值為true時(shí),在IsPostBack中動(dòng)態(tài)

我們?cè)O(shè)計(jì)的分層架構(gòu),層與層之間應(yīng)該是松散耦合的。因?yàn)槭菃蜗騿我徽{(diào)用,所以,這里的“松散耦合”實(shí)際是指上層類不能具體依賴于下層類,而應(yīng)該依賴于下層提供的一個(gè)接口。這樣,上層類不能直接實(shí)例化下層中的類,而只持有接口,至于接口所指變量最終究竟是哪一個(gè)類,則由依賴注入機(jī)制決定。

之所以這樣做,是為了實(shí)現(xiàn)層與層之間的“可替換”式設(shè)計(jì),例如,現(xiàn)在需要換一種方式實(shí)現(xiàn)數(shù)據(jù)訪問層,只要這個(gè)實(shí)現(xiàn)遵循了前面定義的數(shù)據(jù)訪問層接口,業(yè)務(wù)邏輯層和表示層不需要做任何改動(dòng),只需要改一下配置文件系統(tǒng)即可正常運(yùn)行。另外,基于這種結(jié)構(gòu)的系統(tǒng),還可以實(shí)現(xiàn)并行開發(fā)。即不同開發(fā)人員可以專注于自己的層次,只有接口被定義好了,開發(fā)出來的東西就可以無縫連接。

在J2EE平臺(tái)上,主要使用Spring框架實(shí)現(xiàn)依賴注入。這里,我們將自己做一個(gè)依賴注入容器。

依賴注入的理論基礎(chǔ)是Abstract Factory設(shè)計(jì)模式,這里結(jié)合具體實(shí)例簡(jiǎn)單介紹一下。

上圖以數(shù)據(jù)訪問層為例,展示了Abstract Factory模式的應(yīng)用。如圖,現(xiàn)假設(shè)有針對(duì)Access和SQLServer兩種數(shù)據(jù)庫的數(shù)據(jù)訪問層,它們都實(shí)現(xiàn)了數(shù)據(jù)訪問層接口。每個(gè)數(shù)據(jù)訪問層有自己的工廠,所有工廠都實(shí)現(xiàn)自IDALFactory接口。而客戶類(這里就是業(yè)務(wù)邏輯層類)僅與工廠接口、數(shù)據(jù)訪問層接口耦合,而與具體類無關(guān),這樣,只要通過配置文件確定實(shí)例化哪個(gè)工廠,就可以得到不同的數(shù)據(jù)訪問層。

然而,這種設(shè)計(jì)雖然可行,但是代碼比較冗余,因?yàn)檫@樣需要為數(shù)據(jù)訪問層的每一個(gè)實(shí)現(xiàn)編寫一個(gè)工廠,業(yè)務(wù)邏輯層也一樣。在以前,我們毫無辦法,但是,.NET平臺(tái)引入的反射機(jī)制,給我們提供了一種解決方案。使用反射,每個(gè)層只需要一個(gè)工廠,然后通過從配置文件中讀出程序集的名稱,動(dòng)態(tài)加載相應(yīng)類。另外,為了提高依賴注入機(jī)制的效率,這里引入緩存機(jī)制。下面來看具體實(shí)現(xiàn)。

配置

首先,需要在Web工程的Web.config文件的<appSettings>節(jié)點(diǎn)下添加如下兩個(gè)項(xiàng):
<add key="DAL" value=""/>
<add key="BLL" value=""/>

這兩個(gè)配置選項(xiàng)分別存儲(chǔ)要應(yīng)用的數(shù)據(jù)訪問和也業(yè)務(wù)邏輯層的程序集名稱。value目前是空,是因?yàn)槟壳斑沒有各個(gè)層次的具體實(shí)現(xiàn)。

實(shí)現(xiàn)緩存操作輔助類

為實(shí)現(xiàn)緩存操作,我們將緩存操作封裝成一個(gè)輔助類,放在Utility工程下,具體代碼如下:

using System;
using System.Web;
using System.Web.Caching;

namespace NGuestBook.Utility
{
/**//// <summary>
/// 輔助類,用于緩存操作
/// </summary>
public sealed class CacheAccess
{
/**//// <summary>
/// 將對(duì)象加入到緩存中
/// </summary>
/// <param name="cacheKey">緩存鍵</param>
/// <param name="cacheObject">緩存對(duì)象</param>
/// <param name="dependency">緩存依賴項(xiàng)</param>
public static void SaveToCache(string cacheKey, object cacheObject, CacheDependency dependency)
{
Cache cache = HttpRuntime.Cache;
cache.Insert(cacheKey, cacheObject, dependency);
}

/**//// <summary>
/// 從緩存中取得對(duì)象,不存在則返回null
/// </summary>
/// <param name="cacheKey">緩存鍵</param>
/// <returns>獲取的緩存對(duì)象</returns>
public static object GetFromCache(string cacheKey)
{
Cache cache = HttpRuntime.Cache;

return cache[cacheKey];
}
}
}

封裝依賴注入代碼

因?yàn)楹芏嘁蕾囎⑷氪a非常相似,為了減少重復(fù)性代碼,我們將可復(fù)用的代碼先封裝在一個(gè)類中。具體代碼如下(這個(gè)類放在Factory工程下):

using System;
using System.Configuration;
using System.Reflection;
using System.Web;
using System.Web.Caching;
using NGuestBook.Utility;

namespace NGuestBook.Factory
{
/**//// <summary>
/// 依賴注入提供者
/// 使用反射機(jī)制實(shí)現(xiàn)
/// </summary>
public sealed class DependencyInjector
{
/**//// <summary>
/// 取得數(shù)據(jù)訪問層對(duì)象
/// 首先檢查緩存中是否存在,如果不存在,則利用反射機(jī)制返回對(duì)象
/// </summary>
/// <param name="className">數(shù)據(jù)訪問類名稱</param>
/// <returns>數(shù)據(jù)訪問層對(duì)象</returns>
public static object GetDALObject(string className)
{
/**//// <summary>
/// 取得數(shù)據(jù)訪問層名稱,首先檢查緩存,不存在則到配置文件中讀取
/// 緩存依賴項(xiàng)為Web.Config文件
/// </summary>
object dal = CacheAccess.GetFromCache("DAL");
if (dal == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
dal = ConfigurationManager.AppSettings["DAL"];
CacheAccess.SaveToCache("DAL", dal, fileDependency);
}

/**//// <summary>
/// 取得數(shù)據(jù)訪問層對(duì)象
/// </summary>
string dalName = (string)dal;
string fullClassName = dalName "." className;
object dalObject = CacheAccess.GetFromCache(className);
if (dalObject == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
dalObject = Assembly.Load(dalName).CreateInstance(fullClassName);
CacheAccess.SaveToCache(className, dalObject, fileDependency);
}

return dalObject;
}

/**//// <summary>
/// 取得業(yè)務(wù)邏輯層對(duì)象
/// 首先檢查緩存中是否存在,如果不存在,則利用反射機(jī)制返回對(duì)象
/// </summary>
/// <param name="className">業(yè)務(wù)邏輯類名稱</param>
/// <returns>業(yè)務(wù)邏輯層對(duì)象</returns>
public static object GetBLLObject(string className)
{
/**//// <summary>
/// 取得業(yè)務(wù)邏輯層名稱,首先檢查緩存,不存在則到配置文件中讀取
/// 緩存依賴項(xiàng)為Web.Config文件
/// </summary>
object bll = CacheAccess.GetFromCache("BLL");
if (bll == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
bll = ConfigurationManager.AppSettings["BLL"];
CacheAccess.SaveToCache("BLL", bll, fileDependency);
}

/**//// <summary>
/// 取得業(yè)務(wù)邏輯層對(duì)象
/// </summary>
string bllName = (string)bll;
string fullClassName = bllName "." className;
object bllObject = CacheAccess.GetFromCache(className);
if (bllObject == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
bllObject = Assembly.Load(bllName).CreateInstance(fullClassName);
CacheAccess.SaveToCache(className, bllObject, fileDependency);
}

return bllObject;
}
}
}

分享:.NET平臺(tái)依賴注入機(jī)制及IoC的設(shè)計(jì)與實(shí)現(xiàn)
我們?cè)O(shè)計(jì)的分層架構(gòu),層與層之間應(yīng)該是松散耦合的。因?yàn)槭菃蜗騿我徽{(diào)用,所以,這里的“松散耦合”實(shí)際是指上層類不能具體依賴于下層類,而應(yīng)該依賴于下層提供的一個(gè)接口。這樣,上層

共2頁上一頁12下一頁
來源:模板無憂//所屬分類:.Net教程/更新時(shí)間:2008-08-22
相關(guān).Net教程