[架構設計] 元件和模組的區別
元件(Component)和模組(Module)又是一對容易混淆的名詞,也常常被用來相互替換。兩者是否有差異往往取決專業背景、所在領域、以及視角。個人總結,從設計上來看,元件強調複用,模組強調職責(內聚、分離),或者說元件是達到可複用要求的模組。
Module, 中文為模組或模組。它的核心意義是分離職責,屬於程式碼級模組化的產出。本身是一組具有一定內聚性程式碼的組合,職責明確。對外的介面可以是鬆散的,也可以是集中的。SEI的定義如下:
An implementation unit of software that provides a coherent set of responsibilities.
它以問題分解的形式,來解決軟體設計問題。它更強調一個內聚的概念,形式上可以是Java中的包,也可以是一個原始碼目錄。
Component,中文稱為元件,或者構件。使用非常比較廣泛,它的核心意義在於複用,相對模組,對於依賴性有更高的要求。
我大概整理了一下,兩個定義 (參考Component based software programming):
- 可以複用的模組,概念上與模塊基本等同,只是明顯有依賴性的要求。(最早提出時概念)。
- Component-Based Software Development中提倡的元件定義如下(Component Software):
- 符合特定的介面要求(互動的要求)。
- 具有明確的上下文依賴 (複用的要求)。
它可以獨立釋出(二進位制或原始碼的形式),也可以進行組合。這樣軟體開發就變成了元件的組裝了。
和OOP中的Objects相比,一個類也可以視為一個元件,但更多的情況下,元件提供了更為高層的系統視角。Component如同一片樹林,Object只是樹。
Eclipse中的Plugin和COM(Component Object Model)就是Component Software的典型代表。
Eclipse中的Plugin和COM(Component Object Model)就是Component Software的典型代表。
兩者的關係取決於軟體本身和視角。Eclipse框架下的一個外掛可能包含若干個模組,因為從Eclipse的角度來看,每個Plugin是用來複用的。
而一個應用的模組(如GUI)下也可能使用了多個元件,因為複用的是每個控制元件。
另外也有人從釋出形式上來區分,其實也不盡然。一個模組可能以靜態庫、動態庫存在(skia被應用到一個應用中的場景),一個元件也可能以原始碼的形式存在(Chromium中的Browser Component)。釋出形式其實是取決於產品需求的,不可能準確的區分出兩個設計上的概念。
歡迎一起討論!
參考:
Component based software programming (WikiBooks)
轉載請註明出處: http://blog.csdn.net/horkychen
相關文章
- iOS 元件化/模組化架構設計實踐iOS元件化架構
- 架構師與程式設計師的區別架構程式設計師
- 程式設計師與架構師的區別程式設計師架構
- SOA架構和微服務架構的區別架構微服務
- 【架構與設計】常見微服務分層架構的區別和落地實踐架構微服務
- H5架構和原生架構的區別H5架構
- 重構、重新架構、再設計與重寫的區別架構
- 領域驅動設計和Clean架構之間的區別? - stackexchange架構
- 軟體架構, 軟體框架,設計模式的區別架構框架設計模式
- SOA架構和微服務架構的區別是什麼?架構微服務
- Android 架構設計:MVC、MVP、MVVM和元件化Android架構MVCMVPMVVM元件化
- Q:Spark和Hadoop的架構區別SparkHadoop架構
- 區塊鏈架構設計區塊鏈架構
- LNMP架構與LNAMP架構的區別LNMP架構
- bs架構與cs架構的區別架構
- 求救,架構和框架什麼區別?架構框架
- java架構-執行緒和程式的區別Java架構執行緒
- 你和架構師的的區別是什麼?架構
- RabbitMQ 元件和架構MQ元件架構
- 告訴你架構師與程式設計師的區別在哪裡架構程式設計師
- 超融合架構與傳統IT架構的區別架構
- X86架構與ARM架構的區別:架構
- 全棧工程師和架構師的區別全棧工程師架構
- 架構設計基礎:單服務.叢集.分散式,基本區別和聯絡架構分散式
- SCA(服務元件架構)程式設計模式元件架構程式設計設計模式
- 初級Java程式設計師和Java架構師的區別:內功心法修煉圖Java程式設計師架構
- 嵌入式軟體架構設計-模組化架構
- 解讀架構,框架,模式,構件,元件,中介軟體之間區別架構框架模式元件
- 《程式設計師必讀之軟體架構》作者Simon Brown:架構師與程式設計師的區別(圖靈訪談)程式設計師架構圖靈
- GPU程式設計--CPU和GPU的設計區別GPU程式設計
- 軟體架構設計原則和模式(上):分層架構設計架構模式
- 淺析HDFS架構和設計架構
- springboot 後臺管理模組架構設計方案Spring Boot架構
- 架構設計之架構的演變架構
- 介面、資料結構、資訊架構的區別資料結構架構
- 四大CPU架構的區別架構
- 架構設計思想-微服務架構設計模式架構微服務設計模式
- 常用的設計架構架構