隨著web前端技術(shù)的發(fā)展允懂,插件化技術(shù)已逐漸被拋棄厕怜,但是理解這三者的概念和區(qū)別,對編程思想的提高仍有幫助蕾总。
1 模塊化
狹義上說:
是指Android studio支持了多個(gè)module開發(fā)時(shí)粥航,提出的模塊化概念。
具體實(shí)踐:把常用的功能生百、控件递雀、基礎(chǔ)類、第三方庫蚀浆、權(quán)限等公共部分抽離封裝缀程,把業(yè)務(wù)拆分成N個(gè)模塊進(jìn)行獨(dú)立(module)的管理。
而所有的業(yè)務(wù)組件都依賴于封裝的基礎(chǔ)庫市俊,業(yè)務(wù)組件之間不做依賴杨凑,這樣的目的是為了讓每個(gè)業(yè)務(wù)模塊能單獨(dú)運(yùn)行。
廣義上說:
將一個(gè)復(fù)雜業(yè)務(wù)實(shí)現(xiàn)摆昧,根據(jù)功能蠢甲、頁面或者其他進(jìn)行不同粒度的劃分程不同的模塊,模塊之間解耦据忘,分別進(jìn)行實(shí)現(xiàn),也就是編程的模塊化思想搞糕。
模塊化的特點(diǎn)是:模塊之間解耦勇吊,可以獨(dú)立管理。
2 組件化
將一個(gè)app的代碼拆分成幾份獨(dú)立的組件窍仰,組件之間是低耦合的汉规,可以獨(dú)立編譯打包;也可以將組件打包到一個(gè)apk中。
【沒有組件化的缺點(diǎn)】:
- (1)項(xiàng)目可維護(hù)性下降针史。隨著項(xiàng)目的增加晶伦,即使有做分包目錄,但是項(xiàng)目會(huì)逐漸失去層次感啄枕,可讀性婚陪、可維護(hù)性下降
- (2)開發(fā)和調(diào)試效率低。開發(fā)和調(diào)試時(shí)频祝,修改了一個(gè)小功能泌参,但是需要重新build整個(gè)項(xiàng)目才能看到結(jié)果,耗費(fèi)時(shí)間
- (3)易阻斷不同業(yè)務(wù)模塊的并發(fā)開發(fā)常空。一個(gè)業(yè)務(wù)模塊的小bug沽一,可能阻斷其他業(yè)務(wù)模塊的開發(fā)和調(diào)試,不同業(yè)務(wù)模塊的并發(fā)開發(fā)會(huì)被阻斷漓糙。
- (4)版本管理困難铣缠。多人聯(lián)合開發(fā)時(shí),在版本管理中容易出現(xiàn)沖突和代碼覆蓋問題昆禽。
【組件化的拆分】
- 按照業(yè)務(wù)(功能)劃分各個(gè)業(yè)務(wù)組件模塊蝗蛙。
【組件化后的優(yōu)點(diǎn)】
- (1)每個(gè)模塊可獨(dú)立編譯,提高了編譯速度为狸;
- (2)開發(fā)只負(fù)責(zé)自己的模塊歼郭,還可以再做的隔離一些,每個(gè)業(yè)務(wù)線只可見自己業(yè)務(wù)模塊的代碼辐棒,避免了誤修改和版本管理問題病曾。
- (3)公共的Lib依然是個(gè)獨(dú)立模塊
與模塊化的區(qū)別:是每個(gè)模塊的角色的轉(zhuǎn)換,一個(gè)組件可以獨(dú)立編譯打包漾根,也可以作為lib集成到整個(gè)apk中
3 插件化
插件化是將一個(gè)apk根據(jù)業(yè)務(wù)功能拆分成不同的子apk(也就是不同的插件)泰涂,每個(gè)子apk可以獨(dú)立編譯打包,最終發(fā)布上線的是集成后的apk辐怕。在apk使用時(shí)逼蒙,每個(gè)插件是動(dòng)態(tài)加載的,插件也可以進(jìn)行熱修復(fù)和熱更新寄疏。
- 從技術(shù)上講是牢,就是解決如何啟動(dòng)未安裝的apk里面的類(主要是四大組件)。
- 主要問題:如何加載類陕截、如何加載資源驳棱、如何管理組件生命周期。
與組件化的主要區(qū)別:
- 形式上的區(qū)別农曲,組件化的單位是module社搅,插件化的單位是apk
- 關(guān)注點(diǎn)不同,插件化更關(guān)注動(dòng)態(tài)加載、熱更新形葬、熱修復(fù)等‘插拔’技術(shù)合呐。
組件化與插件化詳細(xì)對比
技術(shù) | 單位 | 實(shí)現(xiàn)內(nèi)容 | 靈活性 | 特性 | 靜動(dòng)態(tài) |
---|---|---|---|---|---|
組件化 | module | 是解耦與加快編譯,隔離不需要關(guān)注的部分 | 按加載時(shí)機(jī)切換笙以,是作為lib淌实,還是apk | 組:組本來就是一個(gè)系統(tǒng),每個(gè)組件不是真正意義上的獨(dú)立模塊 | 靜態(tài)加載 |
插件化 | apk | 是解耦與加快編譯源织,同時(shí)實(shí)現(xiàn)熱插拔也就是熱更新 | 加載的是apk翩伪,可以動(dòng)態(tài)下載,動(dòng)態(tài)更新谈息,比組件化更靈活 | 插:是獨(dú)立的apk缘屹,每個(gè)插件可以作為一個(gè)完全獨(dú)立的apk運(yùn)行,也可以和其他插件集成為大apk | 動(dòng)態(tài)加載侠仇,只用真正使用某個(gè)插件時(shí)轻姿,才加載該插件 |
目前熱門的插件化方案有:阿里的atlas,360公司的RePlugin逻炊,滴滴的VirtualAPK等等互亮;
ps:以上均是在前人分析的基礎(chǔ)上的理解總結(jié)。
參考:
http://www.reibang.com/p/3260baad0979
http://www.reibang.com/p/f5212cf7df55