成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

為什么依賴注入對于程序員來說是件好事?

開發 前端
為什么依賴注入對于程序員來說是件好事?本文將用Kotlin編寫示例說明這一問題的,但其中并未使用該特殊語法功能,因此每位程序員都能理解。

本文轉載自公眾號“讀芯術”(ID:AI_Discovery)。

為什么依賴注入對于程序員來說是件好事?本文將用Kotlin編寫示例說明這一問題的,但其中并未使用該特殊語法功能,因此每位程序員都能理解。

[[338867]]

如果咖啡機不在咖啡館應該怎么辦?如果有一個空白空間,每次想喝咖啡時,就必須從頭開始構造機器。軟件中的運行速度要比在現實中快一百萬倍,因此可以合理編寫如下代碼:

  1. classProgrammer { 
  2.              funtakeBreak() { 
  3.                              //constructing anew coffee machine: 
  4.                  val coffeeMachine =EspressoCoffeeMachine() 
  5.                              coffeeMachine.pourCoffee() 
  6.                       .into(coffeeCup) 
  7.                       .awaitCompletion() 
  8.                      drink(coffeeCup) 
  9.              } 
  10.           } 

但問題是,使用空的構造函數實際上并不能構造咖啡機。雖然結構性能也許不算一個因素,但使用咖啡機時所涉及的結構復雜性一定包含在內:

  1. classProgrammer { 
  2.              funtakeBreak() { 
  3.                      val waterTank =waterTankProvider.getWaterTank() 
  4.                  if (waterTank ==null) { 
  5.                       //TODO: handlefailed to provide water tank. 
  6.                       return 
  7.                  } 
  8.                      val beansContainer =beansContainerProvider.getBeansContainer() 
  9.                  if (beansContainer ==null) { 
  10.                       //TODO: handlefailed to provide beans container. 
  11.                       return 
  12.                  } 
  13.                      val milkContainer =milkContainerProvider.getMilkContainer() 
  14.                  if (milkContainer ==null) { 
  15.                       //TODO: handlefailed to provide milk container 
  16.                       return 
  17.                  } 
  18.                      val milkPump =milkPumpProvider.getMilkPump() 
  19.                  if (milkPump ==null) { 
  20.                       //TODO: handlefailed to provide milk pump 
  21.                       return 
  22.                  } 
  23.                      //constructing anew coffee machine: 
  24.                  val coffeeMachine =EspressoCoffeeMachine
  25.                       waterTank, 
  26.                       beansContainer, 
  27.                       milkContainer, 
  28.                       milkPump, 
  29.                  ) 
  30.                      coffeeMachine.pourCoffee() 
  31.                       .into(coffeeCup) 
  32.                       .awaitCompletion() 
  33.                      drink(coffeeCup) 
  34.              } 
  35.           } 

你能從代碼中看出程序員在休息時做了什么嗎?

僅僅因為無法構建咖啡機,程序員就不喝咖啡而return(返回)工作嗎?在喝咖啡前,程序員怎么可能與所有providers(供應商)交談呢?這些都是可憐的programmer(程序員)的擔憂,他們只想喝到咖啡。

可以把它們都轉移到另一個用于構造咖啡機的類中,實際上,這就是工廠設計模式(Factorydesign pattern)。

  1. classProgrammer { 
  2.              funtakeBreak() { 
  3.                              //Constructs new CoffeeMachineFactory 
  4.                  val coffeeMachineFactory =CoffeeMachineFactory() 
  5.     
  6.                              val coffeeMachine =coffeeMachineFactory.create() 
  7.                              coffeeMachine.pourCoffee() 
  8.                       .into(coffeeCup) 
  9.                       .awaitCompletion() 
  10.                      drink(coffeeCup) 
  11.              } 
  12.           } 

它清潔了代碼,但這遲早會不得不再次改變。程序員們被寵壞了:我們喜歡嘗試來自不同工廠、不同機器所制造的咖啡。

  1. classProgrammer { 
  2.              funtakeBreak() { 
  3.                      val brand =brandProvider.getBrand() 
  4.                  if (brand ==null) { 
  5.                       //TODO: handlefailed to provide brand 
  6.                       return 
  7.                  } 
  8.                      valcoffeeMachineFactory =coffeeMachineFactoryProducer.produceFactoryBy(brand) 
  9.                  if (coffeeMachineFactory ==null) { 
  10.                       //TODO: handlefailed to provide CoffeeMachineFactory 
  11.                       return; 
  12.                  } 
  13.                      val machineModel =coffeeMachineModelProvider.getMachineModel() 
  14.                  if (machineModel ==null) { 
  15.                       //TODO: handle failed to provideCoffeeMachineModel 
  16.                       return; 
  17.                  } 
  18.                      val coffeeMachine = coffeeMachineFactory.create(machineModel) 
  19.                      coffeeMachine.pourCoffee() 
  20.                       .into(coffeeCup) 
  21.                       .awaitCompletion() 
  22.                      drink(coffeeCup) 
  23.              } 
  24.           } 

如你所見,工廠延遲了構造復雜性,但并未使其消失。

[[338868]]

圖源:unsplash

在現實生活中,建造工具和使用工具是兩個完全分離的過程。人類一直在利用這一點,史前人類打磨好矛槍后才準備刺殺猛犸象。

程序員不需要在休息時忙著構造咖啡機。他們當然不需要從工廠帶來一個新機器,咖啡機只是程序員用來快速制作咖啡的工具罷了,這樣就能回到自己真正的工作中:寫代碼!

那么,依賴注入與這些有什么關系呢?

依賴注入是一種將類的構造代碼與其使用過程進行系統化分離的體系結構方法。方法有幾種,構造依賴倒置(constructiondependencies inversion)就是其中之一。

它意味著CoffeeMachine(咖啡機)的構造與使用咖啡機的Programmer(程序員)不應該緊密耦合。相反,Programmer(程序員)的構造直觀上應該依賴于CoffeeMachine(咖啡機)。

  1. classProgrammer/*constructor*/( 
  2.                      //class member automatically assigned bythe constructor 
  3.                      privateval coffeeMachine:CoffeeMachine 
  4.                  ) { 
  5.                      funtakeBreak() { 
  6.                          coffeeMachine.pourCoffee() 
  7.                              .into(coffeeCup) 
  8.                              .awaitCompletion() 
  9.                      drink(coffeeCup) 
  10.                      } 
  11.                  } 

但是,這不是僅僅把咖啡機的構造轉移到容納程序員的類中嗎?

不一定。舉個例子,一家SoftwareCompanyX(軟件公司X)希望招到一名Programmer(程序員):再次按照依賴倒置原則,使SoftwareCompanyX的構造依賴于Programmer即可,而不是將Programmer的構造與SoftwareCompanyX緊密耦合。

  1. classSoftwareCompanyX/*constructor*/( 
  2.                      //class member automatically assigned bythe constructor 
  3.                      privateval programmer:Programmer 
  4.                  ) : /*implements*/SoftwareCompany { 
  5.                            overridefunstartWorkingDay() { 
  6.                          programmer.takeBreak() 
  7.                      } 
  8.                  } 

如此一來,Programmer(程序員)可以輕易轉移到另一家SoftwareCompany(軟件公司),休閑地喝一杯咖啡。她所需要的只是能為她提供 CoffeeMachine(咖啡機)參考的人,然后她就可以回來工作了。

最終,必須有人來進行構造。這個人將是唯一需要處理特定類群的構造細節的人,這也是他的唯一任務。構成的根源就是大多數依賴注入框架中的Module(模塊)。

  1. classSoftwareCompanyModule { 
  2.                  funprovideSoftwareCompany():SoftwareCompany { 
  3.                               returnSoftwareCompanyX(provideProgrammer()) 
  4.                           } 
  5.                  privatefunprovideProgrammer():Programmer { 
  6.                               returnAndroidDeveloper(provideCoffeeMachine(provideFactory())) 
  7.                           } 
  8.                  privatefunprovideCoffeeMachine(factory:CoffeeMachineFactory):CoffeeMachine { 
  9.                               returnfactory.create(provideMachineModel()) 
  10.                           } 
  11.                  privatefunprovideMachineModel():String { 
  12.                               returnBuildConfig.COFFEE_MACHINE_MODEL 
  13.                           } 
  14.                  privatefunprovideFactory():CoffeeMachineFactory { 
  15.                               returnCoffeeMachineFactory(provideCoffeeMachineBrand()) 
  16.                           } 
  17.                  privatefunprovideCoffeeMachineBrand():String { 
  18.                               returnBuildConfig.COFFEE_MACHINE_BRAND 
  19.                           } 
  20.                       } 

所以,SoftwareCompanyModule (軟件公司模塊)負責連接一切,并只對外公開SoftwareCompany(軟件公司)。

  1. classSiliconValley { 
  2.                  privateval softwareCompany:SoftwareCompany 
  3.                  init { 
  4.                      softwareCompany =softwareCompanyModule.provideSoftwareCompany() 
  5.                 } 
  6.                  funonDayStart() { 
  7.                      softwareCompany.startWorkingDay() 
  8.                 } 
  9.              } 

所以,為什么需要依賴注入框架呢?

以下問題需要得到解答:

  • 誰應該將模塊實例化?
  • 如果一個模塊依賴于其他模塊該怎么辦?
  • 怎么在不同地方共享同一對象實例?
  • 單元測試怎么樣?

[[338869]]

圖源:unsplash

依賴注入框架有助于應對這些挑戰,這樣就能專注于自己所在領域的挑戰,而不用從頭開始設計。咖啡時間結束了,希望你能學到一些新知識。

 

責任編輯:趙寧寧 來源: 讀芯術
相關推薦

2020-12-08 11:51:55

碎片化物聯網IOT

2022-06-02 14:32:36

加密貨幣比特幣以太坊

2019-08-01 14:38:19

物聯網機器學習人工智能

2022-09-22 14:49:37

智能建筑物聯網

2022-08-22 12:03:25

代碼技術

2015-05-18 10:59:38

程序員選擇比努力更重要

2014-08-15 11:07:09

程序員

2016-03-15 08:51:12

程序員生活怪異

2012-09-06 10:30:58

2011-12-20 09:01:25

.NET

2015-09-24 09:04:36

程序員

2013-10-29 10:24:31

程序員漫畫

2011-08-11 14:52:59

2011-09-18 09:42:08

程序員

2015-06-05 14:15:13

程序員難升職

2013-08-05 13:26:05

2013-06-28 13:28:09

2015-12-14 16:19:43

LPWA物聯網

2016-03-25 10:11:57

BYOD自帶設備

2011-12-27 09:07:36

程序員
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 福利精品| 成人av播放 | 91佛爷在线观看 | 欧美精品久久 | 日韩中文在线视频 | 中文av在线播放 | 在线播放91 | 妞干网视频| 午夜日韩 | 欧美激情精品久久久久久变态 | www日本在线播放 | 毛片免费观看 | 在线免费观看成人 | 国产精品视频久久 | 精品在线一区二区三区 | 亚洲欧美aⅴ | www.蜜桃av.com | 欧美一级免费黄色片 | a久久| 欧美日韩91 | av中文字幕在线 | 亚洲精品免费在线 | 美女131mm久久爽爽免费 | 亚洲精品一 | 久久久激情视频 | 亚洲1区| 亚洲 欧美 日韩在线 | 热久色| 精品久久久久久一区二区 | 欧美中文在线 | 97超碰站 | 久久影音先锋 | 亚洲91| 日韩免费在线视频 | 免费成人av网站 | 日韩av在线一区二区 | 久久高清精品 | caoporn视频| 天天天操天天天干 | 国产精品中文字幕一区二区三区 | 在线观看亚洲专区 |