控制反转 IOC 与依赖注入 DI
引言
簡(jiǎn)單總結(jié)和鞏固一下spring的核心原理——IOC和DI的概念,為什么IOC要叫控制反轉(zhuǎn)?IOC和DI的關(guān)系是怎樣的?
一、IOC 控制反轉(zhuǎn)
初學(xué)者可能很好奇,為什么spring framework的對(duì)象托管容器叫做 IOC容器(Inversion of control)?
設(shè)想這樣一個(gè)場(chǎng)景,A對(duì)象依賴B對(duì)象。如果 new A,就需要先 new B,這是最基本的依賴創(chuàng)建方式。我們管 A 去申請(qǐng) B 對(duì)象的過(guò)程,稱為“資源查找”,可以理解為 A 對(duì)象需要向虛擬機(jī)申請(qǐng)一個(gè)資源 B 對(duì)象。
傳統(tǒng)的資源查找(如上所述)要求組件向容器(可以理解為JVM)主動(dòng)發(fā)起請(qǐng)求,查找資源作為響應(yīng),容器適時(shí)返回資源。
這種方式要求每個(gè) Java 對(duì)象必須自己控制實(shí)例化的過(guò)程。存在的問(wèn)題就是,當(dāng)依賴對(duì)象過(guò)多,層層依賴等情況,創(chuàng)建對(duì)象的過(guò)程將會(huì)極其復(fù)雜和冗長(zhǎng),極大地降低了代碼的維護(hù)性和健壯性。
IOC資源查找方式是容器根據(jù)配置文件的描述統(tǒng)一管理組件的構(gòu)造和依賴,主動(dòng)注入依賴。對(duì)象創(chuàng)建的控制權(quán)由傳統(tǒng)方式的對(duì)象主動(dòng)發(fā)起資源申請(qǐng),變?yōu)閷?duì)象被動(dòng)接收依賴注入。因此得名 Inversion of control 控制反轉(zhuǎn)。
IOC是一種更側(cè)重于原理的技術(shù)描述,它描述了一種被動(dòng)依賴注入的對(duì)象托管服務(wù)理念。
二、DI 依賴注入
Dependency Injection 依賴注入,是比 IOC 更廣泛的概念,它包含 IOC ,因此 IOC 有時(shí)候也稱為 DI 。
任何情況的對(duì)象組裝都可以稱為依賴注入,如前面提到的創(chuàng)建 A 時(shí),通過(guò)構(gòu)造器或?qū)傩再x值傳入 對(duì)象 B,這就是依賴注入的含義。
顯而易見(jiàn),由前面提到的“傳統(tǒng)資源查找”的對(duì)象創(chuàng)建方式屬于“主動(dòng)依賴注入”,而 IOC 就屬于被動(dòng)依賴注入。
不過(guò)隨著被動(dòng)依賴注入的理念深入人心,IOC 與 DI 的概念經(jīng)常一并提起,因此有時(shí)候二者也會(huì)混用,但實(shí)際上 DI 是包含 IOC 的。
DI 可以理解為 IOC 的另一種表達(dá)方式,即組件以一些預(yù)先定義好的方式(如 setter)接收來(lái)自容器的資源注入。相比于IOC 而言,這種表達(dá)方式更加直觀易懂。
總結(jié)
以上是生活随笔為你收集整理的控制反转 IOC 与依赖注入 DI的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python绘制饼图程序_python使
- 下一篇: word公式编辑器_毕业论文里面的各种公