IOC 概述
Spring框架最核心的思想之一就是 控制反轉(zhuǎn)(IOC - Inversion Of Control)
IOC最常見(jiàn)的一種方式叫作 依賴(lài)注入(DI - Dependency Injection)
需要明確的是袁勺,控制反轉(zhuǎn)并不是什么技術(shù)冲粤,而是一種設(shè)計(jì)思想席楚,就是將原本在程序中手動(dòng)創(chuàng)建對(duì)象的控制權(quán)蓖议,交由Spring容器來(lái)統(tǒng)一管理。
理解IOC的關(guān)鍵在于淀散,控制了什么棋傍?什么是反轉(zhuǎn)?
控制了什么:傳統(tǒng)程序設(shè)計(jì)時(shí)彻采,我們直接在程序內(nèi)部通過(guò)
new
關(guān)鍵字進(jìn)行創(chuàng)建對(duì)象腐缤,是程序主動(dòng)去創(chuàng)建對(duì)象,而IOC是由一個(gè)專(zhuān)門(mén)的容器來(lái)統(tǒng)一創(chuàng)建并管理這些對(duì)象肛响。如何理解反轉(zhuǎn):要理解反轉(zhuǎn)岭粤,首先我們要明確什么是正控。正控就是如果我們?cè)谑褂脤?duì)象時(shí)特笋,由我們自己去負(fù)責(zé)對(duì)象的創(chuàng)建剃浇。也就是程序代碼中顯示的創(chuàng)建對(duì)象。而反轉(zhuǎn)猎物,則是需要依賴(lài)所在容器來(lái)創(chuàng)建及注入依賴(lài)的對(duì)象虎囚。反轉(zhuǎn)了什么呢?獲得依賴(lài)對(duì)象的過(guò)程被反轉(zhuǎn)蔫磨,對(duì)象的創(chuàng)建和銷(xiāo)毀不再全部由程序控制淘讥,而由Spring容器來(lái)控制。
所以堤如,字面上可以理解為:當(dāng)一個(gè)對(duì)象創(chuàng)建時(shí)蒲列,程序所依賴(lài)的對(duì)象由外部傳遞給它窒朋,而非自己去創(chuàng)建所依賴(lài)的對(duì)象(比如通過(guò)new操作)。因此嫉嘀,也可以說(shuō)在對(duì)象如何獲取它的依賴(lài)這件事上炼邀,控制權(quán)被反轉(zhuǎn)了。這便不難理解控制反轉(zhuǎn)和依賴(lài)注入這兩個(gè)名字的由來(lái)剪侮。
IOC 能做什么
簡(jiǎn)單舉個(gè)栗子:
在傳統(tǒng)的面向?qū)ο筌浖到y(tǒng)中拭宁,它的底層實(shí)現(xiàn)都是由多個(gè)對(duì)象組成的,彼此合作瓣俯,最終實(shí)現(xiàn)業(yè)務(wù)邏輯杰标。
Like This:
而加入了IOC容器后,容器可以實(shí)現(xiàn)對(duì)象間的解耦:把創(chuàng)建和查找依賴(lài)對(duì)象的控制權(quán)交給容器彩匕,由容器進(jìn)行諸如和組合對(duì)象腔剂,所以對(duì)象之間是松散耦合,這樣也方便于測(cè)試驼仪,同時(shí)也利于功能的復(fù)用掸犬,使得程序在整體結(jié)構(gòu)上便得非常靈活。
IOC很好的體現(xiàn)了面向?qū)ο蟮脑O(shè)計(jì)法則之一——好萊塢法則:Don't call me. I’ll call you.
即由IOC容器幫你找對(duì)象相應(yīng)的依賴(lài)對(duì)象并注入绪爸,而不是由對(duì)象主動(dòng)去找湾碎。
具體來(lái)說(shuō),調(diào)用方?jīng)]有和某個(gè)具體的Service
類(lèi)耦合到一起奠货,而是只依賴(lài)于抽象的接口介褥,這樣,上層業(yè)務(wù)就和底層服務(wù)解耦了递惋。體現(xiàn)了面向?qū)ο蟮?strong>依賴(lài)倒置原則柔滔,也就是面向接口編程的設(shè)計(jì)理念。如果我要改用其他實(shí)現(xiàn)萍虽,那么無(wú)需對(duì)業(yè)務(wù)代碼做改動(dòng)睛廊,只需要修改注入的Bean就可以實(shí)現(xiàn)。這也是典型的開(kāi)放—封閉原則的例子杉编。
IoC 如何實(shí)現(xiàn)
最后我們簡(jiǎn)單說(shuō)一下IoC是如何實(shí)現(xiàn)的喉前。我們?nèi)绻獙?shí)現(xiàn)一個(gè)依賴(lài)注入的功能,怎么做王财?其實(shí)就是如下三個(gè)步驟:
- 1)掃描注解或者配置文件,拿到Bean依賴(lài)服務(wù)實(shí)現(xiàn)的具體類(lèi)名裕便。
- 2)使用反射機(jī)制绒净,基于雷鳴實(shí)例化對(duì)應(yīng)對(duì)象的實(shí)例。
- 3)將對(duì)象實(shí)例偿衰,注入到需要依賴(lài)的地方挂疆。(構(gòu)造器改览,或者 setter 方法 )
會(huì)發(fā)現(xiàn)原理其實(shí)并不難,Spring也是這么做的缤言。只是實(shí)現(xiàn)的功能更全面也更復(fù)雜宝当。
在下一篇文章,將會(huì)講解在Spring中胆萧,是如何實(shí)現(xiàn)IOC的庆揩,以及Spring IOC的高級(jí)特性。
Spring_IOC_02——原理解析
(如果有什么錯(cuò)誤或者建議跌穗,歡迎留言指出)
(本文內(nèi)容是對(duì)各個(gè)知識(shí)點(diǎn)的轉(zhuǎn)載整理订晌,用于個(gè)人技術(shù)沉淀,以及大家學(xué)習(xí)交流用)
參考資料:
張開(kāi)濤——IOC基礎(chǔ)
簡(jiǎn)書(shū)——Spring IOC詳解
Spring的IOC原理(通俗解釋)
源碼解讀Spring IOC原理