高內(nèi)聚低耦合法則實(shí)例解析
定義:一個(gè)對(duì)象應(yīng)該對(duì)其他對(duì)象保持最少的了解。
問(wèn)題由來(lái):類與類之間的關(guān)系越來(lái)越密切,耦合度越來(lái)越大,當(dāng)一個(gè)類發(fā)生改變時(shí),對(duì)另外一個(gè)類的影響也越大.
解決方案:盡量降低類與類之間的耦合.
自從我們接觸到編程開(kāi)始,就知道了軟件設(shè)計(jì)的總的原則,低耦合,高內(nèi)聚,無(wú)論是面向?qū)ο蠡蛘呙嫦蜻^(guò)程,耦合度盡量低,才能提高代碼的復(fù)用率。但是編程怎么編程低耦合呢?
無(wú)論邏輯怎么復(fù)雜,對(duì)于依賴的類來(lái)說(shuō),都盡量將邏輯封裝在類的內(nèi)部,對(duì)外除了提供的public方法,不對(duì)外泄露任何信息。還有一個(gè)更加簡(jiǎn)單的定義:只與直接的朋友通信。首先解釋一下什么是直接的朋友;每個(gè)對(duì)象都會(huì)與其他對(duì)象發(fā)生耦合關(guān)系,我們就說(shuō)這兩個(gè)對(duì)象之間有耦合關(guān)系,我們就說(shuō)這兩個(gè)對(duì)象有朋友關(guān)系,耦合發(fā)生的方式有很多,依賴,關(guān)聯(lián),組合,聚合等等。其中,我們稱出現(xiàn)成員變量,方法參數(shù),方法返回值的類稱為直接的朋友,而出現(xiàn)在局部變量中的類為不是直接的朋友,也就是說(shuō),陌生的類最好不要作為局部變量的形式出現(xiàn)在類的內(nèi)部;
舉一個(gè)例子,在一所學(xué)校,里面有老師若干名,依次編號(hào)。下面有學(xué)生若干名,一次編號(hào)。現(xiàn)在要求打印出所有的老師和學(xué)生的ID.
先來(lái)違反低耦合高內(nèi)聚原則
代碼如下。
package test1;
import java.util.ArrayList;
import java.util.List;
class Teacher{
privateString id;
publicvoidsetId(String id)
{
this.id=id;
}
publicString getId()
{
return id;
}
}
class Student{
private String id;
public void setId(String id)
{
this.id=id;
}
public String getId()
{
return id;
}
}
class StudentManage{
publicList<Student> getAllStudent()
{
List<Student> list=newArrayList<Student>();
for (int i=0;i<100;i++)
{
Student student=new Student();
student.setId("學(xué)生學(xué)號(hào)是"+i);
list.add(student);
}
return list;
}
}
class TeacherManage
{
publicList<Teacher> getAllTeacher()
{
List<Teacher> list=newArrayList<Teacher>();
for (inti=0;i<100;i++)
{
Teacher teacher =new Teacher();
teacher.setId("老師編號(hào)"+i);
list.add(teacher);
}
return list;
}
public void printAllPerson(StudentManagestudentmanager)
{
List<Student>list1=studentmanager.getAllStudent();
for (Student s:list1)
{
System.out.println(s.getId());
}
List<Teacher>list2=this.getAllTeacher();
for (Teacher t:list2)
{
System.out.println(t.getId());
}
}
}
public classClient {
publicstaticvoidmain(String[] args) {
TeacherManagetm=newTeacherManage();
tm.printAllPerson(new StudentManage());
}
}
現(xiàn)在這個(gè)設(shè)計(jì)的主要問(wèn)題出現(xiàn)在TeacherManage類中,根據(jù)低耦合高內(nèi)聚法則,只與直接的朋友進(jìn)行通信,而Student類并不是TeacherManage類中的直接朋友,應(yīng)避免類中出現(xiàn)這樣非直接朋友關(guān)系的耦合。
修改之后代碼如下:
package test2;
import java.util.ArrayList;
import java.util.List;
class Teacher{
privateString id;
publicvoidsetId(String id)
{
this.id=id;
}
publicString getId()
{
return id;
}
}
class Student{
private String id;
public void setId(String id)
{
this.id=id;
}
public String getId()
{
return id;
}
}
class StudentManage{
publicList<Student> getAllStudent()
{
List<Student> list=newArrayList<Student>();
for (int i=0;i<100;i++)
{
Student student=new Student();
student.setId("學(xué)生學(xué)號(hào)是"+i);
list.add(student);
}
return list;
}
public void printAllStudent()
{
List<Student>list1=this.getAllStudent();
for (Student s:list1)
{
System.out.println(s.getId());
}
}
}
class TeacherManage
{
publicList<Teacher> getAllTeacher()
{
List<Teacher> list=newArrayList<Teacher>();
for (inti=0;i<100;i++)
{
Teacher teacher =new Teacher();
teacher.setId("老師編號(hào)"+i);
list.add(teacher);
}
return list;
}
publicvoidprintAllTeacher()
{
List<Teacher> list2=this.getAllTeacher();
for (Teacher t:list2)
{
System.out.println(t.getId());
}
}
}
public classClient {
publicstaticvoidmain(String[] args) {
TeacherManagetm=newTeacherManage();
tm.printAllTeacher();
StudentManagesm=newStudentManage();
sm.printAllStudent();
}
}
修改后,學(xué)生新增加了學(xué)生ID的方法,老師直接來(lái)調(diào)用即可。從而避免了與學(xué)生發(fā)生耦合。低耦合高內(nèi)聚原則的初衷是降低了類之間的耦合,由于每個(gè)類減少了不必要的依賴,因此的確可以降低耦合關(guān)系,但是凡事有個(gè)度,雖然可以避免與非直接的類通信,但是要通信,必然會(huì)通過(guò)一個(gè)“中介”來(lái)發(fā)生關(guān)系。采用此法則可以做到結(jié)構(gòu)清晰,高內(nèi)聚低耦合、
耦合性與內(nèi)聚性是模塊獨(dú)立性的兩個(gè)定性標(biāo)準(zhǔn),將軟件系統(tǒng)劃分模塊時(shí),盡量做到高內(nèi)聚低耦合,提高模塊的獨(dú)立性,為設(shè)計(jì)高質(zhì)量的軟件結(jié)構(gòu)奠定基礎(chǔ)。
有個(gè)例子很容易明白:一個(gè)程序有50個(gè)函數(shù),這個(gè)程序執(zhí)行得非常好;然而一旦你修改其中一個(gè)函數(shù),其他49個(gè)函數(shù)都需要做修改,這就是高耦合的后果。
總結(jié)
以上就是本文關(guān)于高內(nèi)聚低耦合法則實(shí)例代碼解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
- Java依賴倒轉(zhuǎn)原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 開(kāi)放封閉原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 接口隔離原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 里氏代換原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 單一職責(zé)原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 高內(nèi)聚低耦合原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 合成聚合復(fù)用原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- 淺談java中OO的概念和設(shè)計(jì)原則(必看)
相關(guān)文章
Spring MVC學(xué)習(xí)之DispatcherServlet請(qǐng)求處理詳析
這篇文章主要給大家介紹了關(guān)于Spring MVC學(xué)習(xí)教程之DispatcherServlet請(qǐng)求處理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
Springboot整合nacos報(bào)錯(cuò)無(wú)法連接nacos的解決
這篇文章主要介紹了Springboot整合nacos報(bào)錯(cuò)無(wú)法連接nacos的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
eclipse啟動(dòng)出現(xiàn)“failed to load the jni shared library”問(wèn)題解決
這篇文章主要介紹了eclipse啟動(dòng)出現(xiàn)“failed to load the jni shared library”問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
簡(jiǎn)單了解mybatis攔截器實(shí)現(xiàn)原理及實(shí)例
這篇文章主要介紹了簡(jiǎn)單了解mybatis攔截器實(shí)現(xiàn)原理及實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
Springboot文件上傳出現(xiàn)找不到指定系統(tǒng)路徑的解決
這篇文章主要介紹了Springboot文件上傳出現(xiàn)找不到指定系統(tǒng)路徑的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Mapstruct對(duì)象插入數(shù)據(jù)庫(kù)某個(gè)字段總是為空的bug詳解
這篇文章主要為大家介紹了在一次需求開(kāi)發(fā)Mapstruct中對(duì)象插入數(shù)據(jù)庫(kù)某個(gè)字段總是為空的bug問(wèn)題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
Spring Boot中使用Spring-data-jpa實(shí)現(xiàn)數(shù)據(jù)庫(kù)增刪查改
本篇文章主要介紹了Spring Boot中使用Spring-data-jpa實(shí)現(xiàn)增刪查改,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-03-03

