欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

高內(nèi)聚低耦合法則實(shí)例解析

 更新時(shí)間:2017年12月25日 11:05:12   作者:佳.Zip  
這篇文章主要介紹了高內(nèi)聚低耦合法則實(shí)例代碼解析,具有一定借鑒價(jià)值,需要的朋友可以參考下。

定義:一個(gè)對象應(yīng)該對其他對象保持最少的了解。

問題由來:類與類之間的關(guān)系越來越密切,耦合度越來越大,當(dāng)一個(gè)類發(fā)生改變時(shí),對另外一個(gè)類的影響也越大.

解決方案:盡量降低類與類之間的耦合.

自從我們接觸到編程開始,就知道了軟件設(shè)計(jì)的總的原則,低耦合,高內(nèi)聚,無論是面向?qū)ο蠡蛘呙嫦蜻^程,耦合度盡量低,才能提高代碼的復(fù)用率。但是編程怎么編程低耦合呢?

無論邏輯怎么復(fù)雜,對于依賴的類來說,都盡量將邏輯封裝在類的內(nèi)部,對外除了提供的public方法,不對外泄露任何信息。還有一個(gè)更加簡單的定義:只與直接的朋友通信。首先解釋一下什么是直接的朋友;每個(gè)對象都會(huì)與其他對象發(fā)生耦合關(guān)系,我們就說這兩個(gè)對象之間有耦合關(guān)系,我們就說這兩個(gè)對象有朋友關(guān)系,耦合發(fā)生的方式有很多,依賴,關(guān)聯(lián),組合,聚合等等。其中,我們稱出現(xiàn)成員變量,方法參數(shù),方法返回值的類稱為直接的朋友,而出現(xiàn)在局部變量中的類為不是直接的朋友,也就是說,陌生的類最好不要作為局部變量的形式出現(xiàn)在類的內(nèi)部;

舉一個(gè)例子,在一所學(xué)校,里面有老師若干名,依次編號(hào)。下面有學(xué)生若干名,一次編號(hào)?,F(xiàn)在要求打印出所有的老師和學(xué)生的ID.

先來違反低耦合高內(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ì)的主要問題出現(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的方法,老師直接來調(diào)用即可。從而避免了與學(xué)生發(fā)生耦合。低耦合高內(nèi)聚原則的初衷是降低了類之間的耦合,由于每個(gè)類減少了不必要的依賴,因此的確可以降低耦合關(guān)系,但是凡事有個(gè)度,雖然可以避免與非直接的類通信,但是要通信,必然會(huì)通過一個(gè)“中介”來發(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í)例代碼解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

相關(guān)文章

  • 關(guān)于mybatis-plus插件使用時(shí)的一些問題小結(jié)

    關(guān)于mybatis-plus插件使用時(shí)的一些問題小結(jié)

    這篇文章主要給大家介紹了關(guān)于mybatis-plus插件使用時(shí)的一些問題的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03
  • 淺談HttpClient、okhttp和RestTemplate的區(qū)別

    淺談HttpClient、okhttp和RestTemplate的區(qū)別

    這篇文章主要介紹了HttpClient、okhttp和RestTemplate的區(qū)別,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 如何自定義Mybatis-Plus分布式ID生成器(解決ID長度超過JavaScript整數(shù)安全范圍問題)

    如何自定義Mybatis-Plus分布式ID生成器(解決ID長度超過JavaScript整數(shù)安全范圍問題)

    MyBatis-Plus默認(rèn)生成的是 64bit 長整型,而 JS 的 Number 類型精度最高只有 53bit,這篇文章主要介紹了如何自定義Mybatis-Plus分布式ID生成器(解決ID長度超過JavaScript整數(shù)安全范圍問題),需要的朋友可以參考下
    2024-08-08
  • Java面試題沖刺第二十二天-- Nginx

    Java面試題沖刺第二十二天-- Nginx

    這篇文章主要為大家分享了最有價(jià)值的三道關(guān)于Nginx的面試題,涵蓋內(nèi)容全面,包括數(shù)據(jù)結(jié)構(gòu)和算法相關(guān)的題目、經(jīng)典面試編程題等,感興趣的小伙伴們可以參考一下
    2021-08-08
  • SpringBoot異步實(shí)現(xiàn) 的8種方式

    SpringBoot異步實(shí)現(xiàn) 的8種方式

    在同步操作中,執(zhí)行到?發(fā)送短信?的時(shí)候,我們必須等待這個(gè)方法徹底執(zhí)行完才能執(zhí)行?贈(zèng)送積分?這個(gè)操作,如果?贈(zèng)送積分?這個(gè)動(dòng)作執(zhí)行時(shí)間較長,發(fā)送短信需要等待,這就是典型的同步場景,這篇文章主要介紹了SpringBoot異步實(shí)現(xiàn) 的8種方式,需要的朋友可以參考下
    2023-11-11
  • Java 將Excel轉(zhuǎn)為OFD格式(方法步驟)

    Java 將Excel轉(zhuǎn)為OFD格式(方法步驟)

    OFD是一種開放版式文檔是我國國家版式文檔格式標(biāo)準(zhǔn),本文通過Java后端程序代碼展示如何將Excel轉(zhuǎn)為OFD格式,分步驟給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2021-12-12
  • Java中l(wèi)ist集合為空或?yàn)閚ull的區(qū)別說明

    Java中l(wèi)ist集合為空或?yàn)閚ull的區(qū)別說明

    這篇文章主要介紹了Java中l(wèi)ist集合為空或?yàn)閚ull的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java小程序賽馬游戲?qū)崿F(xiàn)過程詳解

    Java小程序賽馬游戲?qū)崿F(xiàn)過程詳解

    這篇文章主要介紹了Java小程序賽馬游戲?qū)崿F(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • 淺談spring aop的五種通知類型

    淺談spring aop的五種通知類型

    這篇文章主要介紹了淺談spring aop的五種通知類型,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • 深入理解Java序列化與反序列化

    深入理解Java序列化與反序列化

    今天教大家深入理解Java的序列化與反序列化,文中介紹的非常詳細(xì),有很多代碼示例,對正在學(xué)習(xí)Java的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05

最新評(píng)論