Spring框架中的ioc的幽默解釋

Spring框架中的ioc的幽默解釋
舉報本文鏈接:http://user.qzone.qq.com/70372494/blog/1209107011

Spring框架中的ioc的幽默解釋
IoC就是Inversion of Control,控制反轉。在Java開發中,IoC意味着將你設計好的類交給系統去控制,而不是在你的類內部控制。這稱爲控制反轉。
  下面我們以幾個例子來說明什麼是IoC
  假設我們要設計一個Girl和一個Boy類,其中Girl有kiss方法,即Girl想要Kiss一個Boy。那麼,我們的問題是,Girl如何能夠認識這個Boy?
  在我們中國,常見的MM與GG的認識方式有以下幾種
  1 青梅竹馬;2 親友介紹;
  3 父母包辦
  那麼哪一種纔是最好呢?
  青梅竹馬:Girl從小就知道自己的Boy。
  public class Girl {
  void kiss(){
  Boy boy = new Boy();
  }
  }
  然而從開始就創建的Boy缺點就是無法在更換。並且要負責Boy的整個生命週期。如果我們的Girl想要換一個怎麼辦?(筆者嚴重不支持Girl經常更換Boy)
  親友介紹:由中間人負責提供Boy來見面
  public class Girl {
  void kiss(){
  Boy boy = BoyFactory.createBoy();
  }
  }
  親友介紹,固然是好。如果不滿意,儘管另外換一個好了。但是,親友BoyFactory經常是以Singleton的形式出現,不然就是,存在於 Globals,無處不在,無處不能。實在是太繁瑣了一點,不夠靈活。我爲什麼一定要這個親友摻和進來呢?爲什麼一定要付給她介紹費呢?萬一最好的朋友愛上了我的男朋友呢?
  父母包辦:一切交給父母,自己不用費吹灰之力,只需要等着Kiss就好了。
  public class Girl {
  void kiss(Boy boy){
  // kiss boy
  boy.kiss();
  }
  }
  Well,這是對Girl最好的方法,只要想辦法賄賂了Girl的父母,並把Boy交給他。那麼我們就可以輕鬆的和Girl來Kiss了。看來幾千年傳統的父母之命還真是有用哦。至少Boy和Girl不用自己瞎忙乎了。
  這就是IOC,將對象的創建和獲取提取到外部。由外部容器提供需要的組件。
  我們知道好萊塢原則:“Do not call us, we will call you.” 意思就是,You, girlie, do not call the boy. We will feed you a boy。
  我們還應該知道依賴倒轉原則即 Dependence Inversion Princinple,DIP。
  Eric Gamma說,要面向抽象編程。面向接口編程是面向對象的核心。
  組件應該分爲兩部分,即
  Service, 所提供功能的聲明
  Implementation, Service的實現
  好處是:多實現可以任意切換,防止 “everything depends on everything” 問題.即具體依賴於具體。
  所以,我們的Boy應該是實現Kissable接口。這樣一旦Girl不想kiss可惡的Boy的話,還可以kiss可愛的kitten和慈祥的grandmother。
  二、IOC的type
  IoC的Type指的是Girl得到Boy的幾種不同方式。我們逐一來說明。
  IOC type 0:不用IOC
  public class Girl implements Servicable {
  private Kissable kissable;
  public Girl() {
  kissable = new Boy();
  }
  public void kissYourKissable() {
  kissable.kiss();
  }
  }
  Girl自己建立自己的Boy,很難更換,很難共享給別人,只能單獨使用,並負責完全的生命週期。
  IOC type 1,先看代碼:
  public class Girl implements Servicable {
  Kissable kissable;
  public void service(ServiceManager mgr) {
  kissable = (Kissable) mgr.lookup(“kissable”);
  }
  public void kissYourKissable() {
  kissable.kiss();
  }
  }
  這種情況出現於Avalon Framework。一個組件實現了Servicable接口,就必須實現service方法,並傳入一個ServiceManager。其中會含有需要的其它組件。只需要在service方法中初始化需要的Boy。
  另外,J2EE中從Context取得對象也屬於type 1。
  它依賴於配置文件
  …
  IOC type 2:
  public class Girl {
  private Kissable kissable;
  public void setKissable(Kissable kissable) {
  this.kissable = kissable;
  }
  public void kissYourKissable() {
  kissable.kiss();
  }
  }
  Type 2出現於Spring Framework,是通過JavaBean的set方法來將需要的Boy傳遞給Girl。它必須依賴於配置文件。
  IOC type 3
  public class Girl {
  private Kissable kissable;
  public Girl(Kissable kissable) {
  this.kissable = kissable;
  }
  public void kissYourKissable() {
  kissable.kiss();
  }
  }
  這就是PicoContainer的組件 。通過構造函數傳遞Boy給Girl.
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章