這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)PHP中依賴注入的原理分析,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)公司是專業(yè)的紅花崗網(wǎng)站建設(shè)公司,紅花崗接單;提供網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行紅花崗網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
什么是依賴注入
依賴注入(DI)的概念雖然聽(tīng)起來(lái)很深?yuàn)W,但是如果你用過(guò)一些新興的php框架的話,對(duì)于DI一定不陌生,因?yàn)樗鼈兌喽嗌偕俣加玫搅艘蕾囎⑷雭?lái)處理類與類之間的依賴關(guān)系。
其實(shí)要理解DI,首先要明白在php中如何傳遞依賴關(guān)系。
第一種方案,也是最不可取的方案,就是在A類中直接用new關(guān)鍵詞來(lái)創(chuàng)建一個(gè)B類,如下代碼所示:
<?phpclass A{ public function __construct() {$b = new B(); }}
為什么這種方案不可取呢?因?yàn)檫@樣的話,A與B就耦合在了一起,也就是說(shuō)A類無(wú)法脫離B類工作。
第二種方案就是在A類的方法中傳入需要的B類,如下代碼所示:
<?phpclass A{ public function __construct(B $b) { }}
這種方法比第一種方案有了改進(jìn),A類不必與B類捆綁在一起,只要傳入的類滿足A類的需求,也可以是C類,也可以是D類等等。
但是這種方案的弊端在于如果A類依賴的類較多,參數(shù)列表會(huì)很長(zhǎng),容易發(fā)生混亂。
第三種方案是使用set方法傳入,如下代碼所示:
這種方法比第一種方案有了改進(jìn),A類不必與B類捆綁在一起,只要傳入的類滿足A類的需求,也可以是C類,也可以是D類等等。 但是這種方案的弊端在于如果A類依賴的類較多,參數(shù)列表會(huì)很長(zhǎng),容易發(fā)生混亂。 第三種方案是使用set方法傳入,如下代碼所示:
<?phpclass A{ public function setB(B $b) {$this->b = $b; }}
這種方案同樣存在和第二種方案一樣的弊端,當(dāng)依賴的類增多時(shí),我們需要些很多很多的set方法。
這時(shí)我們?cè)谙肴绻幸粋€(gè)專門的類(或者說(shuō)一個(gè)容器)可以幫我們管理這些依賴關(guān)系就好了。
如下代碼來(lái)自twittee:
<?phpclass Container { private $s=array(); function __set($k, $c) { $this->s[$k]=$c; } function __get($k) { return $this->s[$k]($this); }}
有了container類之后我們可以怎樣管理A與B之間的依賴關(guān)系呢,用代碼說(shuō)話吧:
<?phpclass A{ private $container; public function __construct(Container $container) {$this->container = $container; } public function doSomeThing() {//do something which needs class B $b = $this->container->getB();//to do }}
再將B類注入到容器類中:
$c = new Container();$c->setB(new B());
還可以傳入一個(gè)匿名函數(shù),這樣B類就不會(huì)在傳入時(shí)就立即實(shí)例化,而是在真正調(diào)用時(shí)才完成實(shí)例化的工作:
$c = new Container();$c->setB(function (){ return new B();});
上述就是小編為大家分享的PHP中依賴注入的原理分析了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
文章標(biāo)題:PHP中依賴注入的原理分析
轉(zhuǎn)載來(lái)于:http://www.rwnh.cn/article28/jcjcjp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)站營(yíng)銷、網(wǎng)頁(yè)設(shè)計(jì)公司、外貿(mào)建站、App開(kāi)發(fā)、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)