《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > IoC模式及其應用
IoC模式及其應用
2016年微型機與應用第06期
(沙洲職業工學院,江蘇 張家港 215600)
摘要: IoC是一種優秀的組件解耦模式,而依賴注入是IoC最流行的實現方式。探討了依賴注入的三種不同的實現方式:構造器注入、屬性注入以及接口注入,并介紹了IoC容器Unity的基本使用方法。
Abstract:
Key words :

  周洪斌

  (沙洲職業工學院,江蘇 張家港 215600)

      摘要:IoC是一種優秀的組件解耦模式,而依賴注入是IoC最流行的實現方式。探討了依賴注入的三種不同的實現方式:構造器注入、屬性注入以及接口注入,并介紹了IoC容器Unity的基本使用方法。

  關鍵詞依賴倒置原則控制反轉;依賴注入;Unity

0引言

  2015年江蘇省高校大學生創新創業訓練計劃立項項目(201511288009Y)在使用簡單三層架構開發數據庫應用程序時,一般都是在業務邏輯層直接創建數據訪問層相應的對象,如:

  public class ProductBLL

  {

  SqlServerDAL dal = new SqlServerDAL();

  public int Add(ProductModel model)

  {

  return dal.Add(model);

  }

  }

  這種方式下由調用者ProductBLL主動創建被依賴對象SqlServerDAL,然后調用被依賴對象的方法,導致調用者與被依賴對象實現類的硬編碼耦合,不利于項目的維護與升級。上述緊耦合的業務邏輯層與數據訪問層的關系如圖1所示。

  

001.jpg

  如果用戶需要將數據庫換成Access或者MySQL,需要修改ProductBLL類內部的代碼,違反了開放封閉原則。開放封閉原則要求“軟件實體(類、模塊、函數等)對擴展是開放的,對修改是封閉的”。依賴倒置原則(Dependency Inversion Principle,DIP)要求“高層模塊不應該依賴于低層模塊,兩者應該依賴于抽象”[1]。因此,業務邏輯層的對象不應該直接依賴于數據訪問層的具體實現對象,而應該通過數據訪問層的抽象接口進行訪問,如圖2所示。通過引入抽象,對于高層模塊而言,低層模塊的實現是可替換的。這實際上也是“開放封閉原則”的體現。

  

002.jpg

1控制反轉

  DIP作為一種軟件設計原則,指明了兩個模塊之間應該如何依賴。而控制反轉(Inversion of Control,IoC)則是一種具體的軟件設計模式,明確了如何解除相互依賴的模塊之間的耦合。IoC是指應用本身不負責依賴對象的創建和維護,而交給一個外部容器來完成。這樣就將控制權由應用轉移到了外部,實現了控制權的反轉[2]。IoC的作用在于降低組件之間的耦合度,減少組件之間的依賴關系,提高程序的靈活性和可維護性。

  依賴注入(Dependency Injection,DI)是IoC模式最流行的實現方式,即由外部容器在運行時動態地將依賴的對象注入到組件中。通過依賴注入,業務邏輯層將不再需要直接創建數據訪問層的對象,從而降低了兩者之間的耦合度。

2依賴注入

  依賴注入提供一種機制,將需要依賴(低層模塊)對象的引用傳遞給被依賴(高層模塊)對象。具體的依賴注入可以分為三種形式,即構造器注入、屬性注入以及接口注入[3]。

  2.1構造器注入

  構造器注入,即通過構造方法傳遞依賴。根據依賴倒置原則,高層模塊不應該依賴于低層模塊,兩者應該依賴于抽象。因此構造方法的參數應該是一個抽象類型。

  首先,需要定義一個接口IDataAccess,并在IDataAccess接口中聲明一個Add方法,代碼如下:

  public interface IDataAccess

  {

  int Add(ProductModel model);

  }

  然后,在SqlServerDAL類中,實現IDataAccess接口,代碼如下:

  public class SqlServerDAL:IDataAccess

  {

  public int Add(ProductModel model)

  {

  //省略具體數據庫操作代碼

  }

  }

  接下來,修改ProductBLL類的代碼,代碼如下:

  public class ProductBLL

  {

  private IDataAccess dal;

  //構造器注入

  public ProductBLL(IDataAccess dal)

  {

  this.dal=dal;//傳遞依賴

  }

  public int Add(ProductModel model)

  {

  return dal.Add(model);

  }

  }

  在這里,將依賴對象SqlServerDAL對象的創建和綁定轉移到ProductBLL類的外部來實現,這樣就解除了兩者之間的緊耦合關系。這時,如果要將數據庫換成Access數據庫時,只需定義一個AccessDAL類,實現IDataAccess接口,然后在外部重新綁定依賴,不需要修改ProductBLL類內部代碼即可實現對Access數據庫的操作。

  2.2屬性注入

  屬性注入,即通過屬性來傳遞依賴。因此,首先需要在依賴類ProductBLL中定義一個屬性,代碼如下:

  public class ProductBLL

  {

  private IDataAccess dal;

  //屬性,接受依賴

  public IDataAccess Dal

  {

  set { dal = value; }

  get { return dal; }

  }

  public int Add(ProductModel model)

  {

  return dal.Add(model);

  }

  }

  然后在外部通過給Dal屬性賦值,從而傳遞依賴。

  2.3接口注入

  接口注入需要先定義一個接口,包含一個設置依賴的方法。然后由依賴類繼承并實現這個接口。

  首先定義一個接口,代碼如下:

  public interface IDependent

  {

  void SetDependence(IDataAccess dal);//設置依賴項

  }

  依賴類實現這個接口,代碼如下:

  public class ProductBLL:IDependent

  {

  private IDataAccess dal;

  //實現接口

  public void SetDependence(IDataAccess dal)

  {

  this.dal = dal;

  }

  public int Add(ProductModel model)

  {

  return dal.Add(model);

  }

  }

  外部則通過SetDependence方法傳遞依賴。相比構造器注入和屬性注入,接口注入顯得有些復雜,使用也不常見。

3IoC容器

  3.1IoC容器概述

  一般在小型項目中可以手動創建依賴對象,并將引用傳遞給被依賴模塊。如:

  IDataAccess dal=new SqlServerDAL();//在外部創建依賴對象

  ProductBLL bll=new ProductBLL(dal);//通過構造器注入依賴

  對于大型項目來說,相互依賴的組件比較多,如果還用手動的方式來創建和注入依賴,效率較低。正因如此,IoC容器誕生了。IoC容器實際上是一個依賴注入框架,它包含以下幾個功能:

  (1)動態創建、注入依賴對象;

  (2)管理對象生命周期;

  (3)映射依賴關系。

  Spring是Java平臺廣泛使用的IoC容器[4],.NET平臺常用的IoC容器包括Unity、Autofac、Spring.NET和Ninject等。Unity是微軟公司推出的一款輕量的、可擴展的依賴注入容器,該項目在Codeplex上的地址為http://unity.codeplex.com,可以下載相應的安裝包和開發文檔[5]。

  3.2Unity應用

  Unity在實際項目中的使用方法如下[6]:

  (1)添加對Microsoft.Practices.Unity.dll、Microsoft.Practices.Unity.Configuration.dll以及Microsoft.Practices.Unity.RegistrationByConvention.dll的引用。

  (2)在項目配置文件的<configSections>節點下注冊名為unity的section,并在<configuration>節點下添加unity配置信息。配置文件樣例如下:

  <?xml version="1.0" encoding="utf-8" ?>

  <configuration>

  <configSections>

  <section name="unity" type="Microsoft.Practices.Unity.Configuration.UnityConfigurationSection,Microsoft.Practices.Unity.Configuration"/>

  </configSections>

  <unity>

  <container name="MyContainer">

  <!--映射關系-->

  <register type="UnityDemo.IDataAccess,UnityDemo"mapTo="UnityDemo.SqlServerDAL,UnityDemo"></register>

  </container>

  </unity>

  <startup>

  <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />

  </startup>

  </configuration>

  (3)在代碼中讀取配置信息,并將配置載入到UnityContainer中。

  //創建容器

  IUnityContainer container = new UnityContainer();

  //載入配置信息

  container.LoadConfiguration("MyContainer");

  //獲取指定名稱的配置節

  UnityConfigurationSection section

  = (UnityConfigurationSection)ConfigurationManager.GetSection("unity");

  //獲取特定配置節下已命名的配置節<container name='MyContainer'>下的配置信息

  section.Configure(container, "MyContainer");

  //創建實現了IDataAccess接口的對象

  IDataAccess dal = container.Resolve<IDataAccess>();

4結論

  IoC能有效降低組件之間的耦合度,提高程序的靈活性和可擴展性。本文圍繞如何實現業務邏輯層與數據訪問層之間的松散耦合,介紹了構造器注入、屬性注入以及接口注入三種不同的依賴注入方式,并介紹了NET平臺下常用IoC容器Unity的使用,展示了IoC在軟件開發領域的實際應用。

參考文獻

  [1] 張逸.軟件設計精要與模式(第2版)[M].北京:電子工業出版社,2010.

  [2] 王程,周安琳.基于Autofac對乳制品安全風險預警系統的擴展設計[J].河北省科學院學報,2013,30(1):14.

  [3] 張浩.利用反向控制原則和依賴注入的可復用框架設計解耦方法[J].計算機應用,2010(12):227229.

  [4] 周嵐.基于Spring框架的IoC模式的設計和實現[J].合肥學院學報(自然科學版),2011,21(1):4953.

  [5] 李鳳桐.微軟企業庫組件Unity使用淺析[J].電腦編程技巧與維護,2015(6):1314.

  [6] 蔣金楠.ASP.NET MVC4框架揭秘[M].北京:電子工業出版社,2013.


此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美区一区二| 国产一区在线免费观看| 久久精品成人一区二区三区| 亚洲影院在线| 亚洲美女精品一区| 亚洲激情在线播放| 亚洲国产91| 久久精品国产亚洲5555| 午夜一区二区三区在线观看| 亚洲一区欧美| 亚洲综合99| 亚洲小少妇裸体bbw| 日韩一级精品| 亚洲精品一区二区三区四区高清| 亚洲高清av| 亚洲成在人线av| 亚洲福利电影| 亚洲黄色成人| 亚洲茄子视频| 亚洲三级电影在线观看| 亚洲精品乱码久久久久久日本蜜臀 | 在线亚洲美日韩| 99re成人精品视频| 99精品国产高清一区二区| 亚洲国产精品久久久久秋霞不卡| 亚洲国产精品美女| 亚洲三级性片| 夜夜嗨av色综合久久久综合网| 99在线精品视频| 亚洲一卡久久| 欧美诱惑福利视频| 久久免费观看视频| 免费在线观看成人av| 欧美激情精品久久久久久免费印度 | 亚洲人成人一区二区在线观看| 久久爱www久久做| 亚洲黑丝在线| 在线视频精品一区| 午夜精品一区二区三区四区| 久久se精品一区精品二区| 久久久亚洲欧洲日产国码αv| 免费久久99精品国产| 欧美日韩国产精品一区二区亚洲| 欧美色网在线| 国产日韩欧美在线观看| 一区二区视频免费完整版观看| 亚洲精品国精品久久99热| 一本久久青青| 欧美一区不卡| 亚洲伦理精品| 亚欧成人精品| 欧美国产日韩视频| 国产精品视频最多的网站| 激情欧美一区二区三区| 99精品热6080yy久久| 小处雏高清一区二区三区| 亚洲人人精品| 欧美一区二区三区免费观看| 蜜桃久久av一区| 国产精品久久久久三级| 国产一区清纯| 亚洲伦理自拍| 欧美在线一区二区三区| 99视频一区二区| 久久成人免费日本黄色| 欧美国产日韩一区二区| 国产伦精品一区二区三区在线观看 | 国产精品福利久久久| 国产在线播放一区二区三区| 亚洲人人精品| 欧美中文在线观看国产| 在线一区二区日韩| 久久久久亚洲综合| 欧美日韩色一区| 国一区二区在线观看| 99国产精品私拍| 亚洲东热激情| 先锋资源久久| 欧美日韩极品在线观看一区| 国产香蕉97碰碰久久人人| 亚洲毛片视频| 亚洲国产另类久久精品| 羞羞漫画18久久大片| 欧美日韩1234| 悠悠资源网久久精品| 亚洲欧美日韩精品在线| 99亚洲视频| 美女日韩在线中文字幕| 国产精品永久| 一区二区高清视频在线观看| 最新中文字幕亚洲| 久久久久在线| 国产精品视区| 一本色道久久综合| 99pao成人国产永久免费视频| 裸体丰满少妇做受久久99精品 | 1769国内精品视频在线播放| 亚洲欧美日韩综合| 亚洲午夜电影网| 欧美精品一区二区三区很污很色的| 黄色成人在线观看| 午夜精品久久久久久久久久久久久 | 亚洲性图久久| 亚洲美女视频在线观看| 久久字幕精品一区| 国产一区二区三区黄视频| 亚洲在线视频一区| 亚洲综合精品四区| 欧美午夜激情在线| 亚洲精品综合久久中文字幕| 亚洲精品一区二区在线| 开心色5月久久精品| 国产一区白浆| 欧美尤物巨大精品爽| 欧美一区不卡| 国产精品入口夜色视频大尺度 | 亚洲综合导航| 性欧美video另类hd性玩具| 欧美三级视频在线播放| 亚洲美女精品久久| 亚洲视频视频在线| 欧美日韩视频在线一区二区| 亚洲美女诱惑| 亚洲视频久久| 国产精品久久久久久久久果冻传媒 | 亚洲日本在线视频观看| 另类av导航| 亚洲第一黄色网| 亚洲精选国产| 欧美日韩精品一区二区在线播放| 亚洲福利视频三区| 亚洲精品字幕| 欧美日韩亚洲一区| 在线亚洲免费| 欧美与欧洲交xxxx免费观看 | 亚洲黄网站在线观看| 欧美成人福利视频| 亚洲精品激情| 亚洲视频 欧洲视频| 国产精品免费视频观看| 亚洲欧美日韩国产中文在线| 久久国产天堂福利天堂| 韩国精品在线观看| 亚洲黄色片网站| 欧美极品一区| 亚洲一区二区伦理| 久久久久久久综合狠狠综合| 一色屋精品视频免费看| 日韩视频在线一区二区三区| 欧美三日本三级三级在线播放| 亚洲一区二区视频在线| 久久男人资源视频| 亚洲欧洲偷拍精品| 亚洲一级黄色| 国产一区二区三区久久 | 亚洲欧美综合另类中字| 国产欧美日韩91| 久久国产精品72免费观看| 欧美成人伊人久久综合网| 99综合精品| 久久国产精品久久久久久电车| 在线不卡中文字幕| 在线一区二区三区四区五区| 国产美女扒开尿口久久久| 亚洲国产欧美一区| 欧美日韩不卡合集视频| 亚洲欧美国产制服动漫| 葵司免费一区二区三区四区五区| 亚洲美女电影在线| 久久精品国产免费观看| 亚洲黄网站黄| 欧美一区二区视频观看视频| 在线观看一区| 亚洲一区日本| 一区二区三区在线视频免费观看 | 欧美中在线观看| 欧美日韩精品伦理作品在线免费观看| 亚洲综合二区| 欧美福利视频网站| 亚洲欧美日韩国产综合在线| 欧美成人tv| 欧美一区二区三区精品电影| 欧美人成网站| 久久精品视频在线看| 国产精品theporn| 亚洲激情影院| 国产日本欧美在线观看| 99热精品在线| 狠狠色狠狠色综合日日小说| 亚洲伊人久久综合| 在线成人中文字幕| 欧美亚洲一区在线| 亚洲精品一区二区网址 | 免费日韩精品中文字幕视频在线| 亚洲天堂黄色| 欧美激情片在线观看| 久久精品人人做人人综合 | 午夜精品偷拍| 欧美视频不卡中文| 亚洲三级网站|