自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

本文轉(zhuǎn)載自公眾號“讀芯術(shù)”(ID:AI_Discovery)。

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

[[338867]]

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

  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.           } 

但問題是,使用空的構(gòu)造函數(shù)實際上并不能構(gòu)造咖啡機。雖然結(jié)構(gòu)性能也許不算一個因素,但使用咖啡機時所涉及的結(jié)構(gòu)復雜性一定包含在內(nèi):

  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.           } 

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

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

可以把它們都轉(zhuǎn)移到另一個用于構(gòu)造咖啡機的類中,實際上,這就是工廠設(shè)計模式(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.           } 

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

[[338868]]

圖源:unsplash

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

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

那么,依賴注入與這些有什么關(guān)系呢?

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

它意味著CoffeeMachine(咖啡機)的構(gòu)造與使用咖啡機的Programmer(程序員)不應(yīng)該緊密耦合。相反,Programmer(程序員)的構(gòu)造直觀上應(yīng)該依賴于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.                  } 

但是,這不是僅僅把咖啡機的構(gòu)造轉(zhuǎn)移到容納程序員的類中嗎?

不一定。舉個例子,一家SoftwareCompanyX(軟件公司X)希望招到一名Programmer(程序員):再次按照依賴倒置原則,使SoftwareCompanyX的構(gòu)造依賴于Programmer即可,而不是將Programmer的構(gòu)造與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(程序員)可以輕易轉(zhuǎn)移到另一家SoftwareCompany(軟件公司),休閑地喝一杯咖啡。她所需要的只是能為她提供 CoffeeMachine(咖啡機)參考的人,然后她就可以回來工作了。

最終,必須有人來進行構(gòu)造。這個人將是唯一需要處理特定類群的構(gòu)造細節(jié)的人,這也是他的唯一任務(wù)。構(gòu)成的根源就是大多數(shù)依賴注入框架中的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.              } 

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

以下問題需要得到解答:

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

[[338869]]

圖源:unsplash

依賴注入框架有助于應(yīng)對這些挑戰(zhàn),這樣就能專注于自己所在領(lǐng)域的挑戰(zhàn),而不用從頭開始設(shè)計??Х葧r間結(jié)束了,希望你能學到一些新知識。

 

責任編輯:趙寧寧 來源: 讀芯術(shù)
相關(guān)推薦

2020-12-08 11:51:55

碎片化物聯(lián)網(wǎng)IOT

2022-06-02 14:32:36

加密貨幣比特幣以太坊

2019-08-01 14:38:19

物聯(lián)網(wǎng)機器學習人工智能

2022-09-22 14:49:37

智能建筑物聯(lián)網(wǎng)

2015-05-18 10:59:38

程序員選擇比努力更重要

2022-08-22 12:03:25

代碼技術(shù)

2013-06-28 13:28:09

2011-08-11 14:52:59

2015-09-24 09:04:36

程序員

2011-09-18 09:42:08

程序員

2015-06-05 14:15:13

程序員難升職

2013-10-29 10:24:31

程序員漫畫

2014-08-15 11:07:09

程序員

2011-12-20 09:01:25

.NET

2012-09-06 10:30:58

2016-03-15 08:51:12

程序員生活怪異

2013-08-05 13:26:05

2016-03-25 10:11:57

BYOD自帶設(shè)備

2015-11-02 09:19:10

程序員JavaScript

2011-04-19 09:59:47

工資程序員
點贊
收藏

51CTO技術(shù)棧公眾號