java面向?qū)ο缶幊填惖膬?nèi)聚性分析
類劃分時關(guān)于內(nèi)聚性的問題
靜態(tài)類的設(shè)計
在軟件設(shè)計中,我們經(jīng)常會將一些通用的方法封裝到一個類中,這種類只包含方法,沒有屬性,類中的方法之間沒有關(guān)聯(lián),內(nèi)聚性最低,屬于偶然內(nèi)聚或巧合內(nèi)聚。這種設(shè)計常用于工具類,一般設(shè)計為靜態(tài)類,這些方法的使用時類似函數(shù)調(diào)用。設(shè)計需注意,將功能基本接近的方法封裝到一個類中,切忌不能將所有的公用方法封裝到一個大類中,如:日期格式轉(zhuǎn)換,數(shù)字轉(zhuǎn)換字符串等。
高內(nèi)聚類的設(shè)計
高內(nèi)聚類的設(shè)計時,按照操作功能進(jìn)行封裝,需遵循單一職責(zé)原則,即每一個類完成規(guī)定的某一項任務(wù)。如:dao層的類用作數(shù)據(jù)的增刪改查(CRUD),數(shù)據(jù)實體僅為數(shù)據(jù)載體,用作傳遞數(shù)據(jù)任務(wù)。即每個封裝的類僅完成一項任務(wù)。
又如迭代器模式中迭代器僅為某一個集合進(jìn)行服務(wù),但是還要獨立出來一個內(nèi)部類,就是把集合數(shù)據(jù)的表示和對集合的遍歷操作兩項任務(wù)分開。
低耦合代表高內(nèi)聚,在進(jìn)行類的設(shè)計時,如類A的方法中調(diào)用了B類的方法,在A類定義屬性變量或局部對象變量時,使用B類接口定義,通過注入或方法參數(shù)傳入B的對象,使得二者之間形成一種松耦合的關(guān)系。如果一個類對外暴露的接口簡單,接口的參數(shù)為簡單數(shù)據(jù)類型,所有的復(fù)雜操作封裝在類的內(nèi)部,這種類內(nèi)聚性最高,獨立性強(qiáng)。如:通過短信貓發(fā)送短信,對外接口僅為sendMsg(String msg),如何創(chuàng)建連接、格式轉(zhuǎn)換、信息發(fā)送全部封裝類的內(nèi)部。
附:面向過程編程中模塊的內(nèi)聚性
以下是面向過程中內(nèi)聚性由高到低做一說明,對類劃分時有一定的參考意義。
偶然內(nèi)聚或巧合內(nèi)聚(Coincidental)
內(nèi)內(nèi)的各成分之間沒有關(guān)聯(lián),只是把分散的功能合并在一起;類A內(nèi)有BCDE四個方法,這四個方法均為public方法,功能含義上各自獨立。前端開發(fā)api,將不同模塊的api放在一起,就是偶然耦合。
var api = { //登錄 getCaptcha: (param) => get(apiBase+"/captcha.jpg", param), adminLogin: (param) => post(apiBase+"/sys/login", param), //部門管理 departmentList:(param) => get(apiBase+"/tywdepart/list", param), departmentAdd:(param) =>post(apiBase+"/tywdepart/save", param), departmentUpdate:(param) =>post(apiBase+"/tywdepart/update", param), departmentDelete:(param) =>post(apiBase+"/tywdepart/delete", param), }
增強(qiáng)耦合度辦法:拆分;將登錄api要使用的api和部門管理api設(shè)計為兩個獨立的api。
邏輯內(nèi)聚(Logical):
若干個邏輯相似的功能通過參數(shù)確定該模塊對應(yīng)哪一個功能。如:類A內(nèi)有BCDE四個方法,這四個方法均為public方法,功能上類似,把它們封裝在一起,如字符串轉(zhuǎn)換函數(shù)工具類,包括int轉(zhuǎn)字符串、double轉(zhuǎn)字符串等。
時間內(nèi)聚(Temporal ):
因為功能必須在同一時間內(nèi)執(zhí)行才寫到一個模塊,即這些功能只是因為時間因素才有關(guān)聯(lián)。 例:程序初始化時,程序員把對所有全局變量的初始化操作放在模塊A中,模塊A中就是時間內(nèi)聚。
過程內(nèi)聚:
模塊內(nèi)部的處理成分是相關(guān)的,而且這些處理必須以特定的次序進(jìn)行執(zhí)行。一個模塊,為某員工計算工齡工資:打開員工信息文件取出員工記錄;按一定的算法計算工 齡;按一定的算法計算工齡工資。 該模塊中的三個相對獨立的子功能必須以特定次序執(zhí)行,整個模塊具有過程內(nèi)聚
通信內(nèi)聚(Communicational):
所有處理元素集中在一個數(shù)據(jù)結(jié)構(gòu)的區(qū)域上。一個模塊,接收一個遠(yuǎn)程傳來的信息文件,保存,同時馬上打印該文件。 該模塊針對同一個文件操作,打印和存盤操作沒有前后順序關(guān)系,整個模塊具有通信內(nèi)聚。
順序內(nèi)聚(Sequential):
模塊內(nèi)的各個處理元素關(guān)注同一功能,順序執(zhí)行,前一元素的輸出結(jié)果作為下一元素的輸入。
功能內(nèi)聚(Functional):
類內(nèi)所有的功能成分均為了完成一項功能服務(wù)的,如:userDao都是為了完成用戶數(shù)據(jù)庫的增刪改查(CRUD)服務(wù)的。
面向過程編程中模塊的內(nèi)聚性參考:
http://www.dbjr.com.cn/article/120602.htm
以上就是java面向?qū)ο缶幊填惖膬?nèi)聚性分析的詳細(xì)內(nèi)容,更多關(guān)于java面向?qū)ο缶幊填惖膬?nèi)聚性的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Spring?容器初始化?register?與?refresh方法
這篇文章主要介紹了Spring?容器初始化?register?與?refresh方法,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07