Java 你知道什么是耦合、如何解(降低)耦合_第1頁
Java 你知道什么是耦合、如何解(降低)耦合_第2頁
Java 你知道什么是耦合、如何解(降低)耦合_第3頁
Java 你知道什么是耦合、如何解(降低)耦合_第4頁
Java 你知道什么是耦合、如何解(降低)耦合_第5頁
已閱讀5頁,還剩1頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

第Java你知道什么是耦合、如何解(降低)耦合目錄什么是耦合性什么是程序間的耦合如何解耦工廠模式解耦案例原因就是:解決思路:解耦合這里,我們先舉個(gè)栗子,比如排序我們?cè)倥e個(gè)栗子,socket

什么是耦合性

耦合性(Coupling),也叫耦合度,是對(duì)模塊間關(guān)聯(lián)程度的度量。模塊間的耦合度是指模塊之間的依賴關(guān)系,包括控制關(guān)系、調(diào)用關(guān)系、數(shù)據(jù)傳遞關(guān)系。模塊間聯(lián)系越多,其耦合性越強(qiáng),同時(shí)表明其獨(dú)立性越差(降低耦合性,可以提高其獨(dú)立性)。

什么是程序間的耦合

假如:當(dāng)我去new一個(gè)對(duì)象的時(shí)候,而這個(gè)對(duì)象不存在,這個(gè)時(shí)候程序會(huì)報(bào)編譯時(shí)異常,也就意味著程序連運(yùn)行都運(yùn)行不了,我們可以理解為他們的耦合度較高。

如何解耦

我們可以利用Java的反射技術(shù),通過類定名,來進(jìn)行反射創(chuàng)建對(duì)象,這個(gè)時(shí)候我們可以成功的避免編譯時(shí)異常,并且保證了項(xiàng)目在這個(gè)時(shí)候還能正常運(yùn)行。

工廠模式解耦

在實(shí)際開發(fā)中我們可以把三層的對(duì)象都使用配置文件配置起來,當(dāng)啟動(dòng)服務(wù)器應(yīng)用加載的時(shí)候,讓一個(gè)類中的方法通過讀取配置文件,把這些對(duì)象創(chuàng)建出來并存起來。在接下來的使用的時(shí)候,直接拿過來用就好了。那么,這個(gè)讀取配置文件,創(chuàng)建和獲取三層對(duì)象的類就是工廠。

案例

早期我們的JDBC操作,注冊(cè)驅(qū)動(dòng)時(shí),我們?yōu)槭裁床皇褂肈riverManager的register方法,而是采用Class.forName的方式?

publicclassJdbcDemo1{

publicstaticvoidmain(String[]args)throwsException{

//1.注冊(cè)驅(qū)動(dòng)

//DriverManager.registerDriver(newcom.mysql.jdbc.Driver());

Class.forName("com.mysql.jdbc.Driver");

//2.獲取連接

//3.獲取預(yù)處理sql語句對(duì)象

//4.獲取結(jié)果集

//5.遍歷結(jié)果集

}

原因就是:

我們的類依賴了數(shù)據(jù)庫的具體驅(qū)動(dòng)類(MySQL),如果這時(shí)候更換了數(shù)據(jù)庫品牌(比如Oracle),需要修改源碼來重新數(shù)據(jù)庫驅(qū)動(dòng)。這顯然不是我們想要的。

解決思路:

當(dāng)是我們講解jdbc時(shí),是通過反射來注冊(cè)驅(qū)動(dòng)的,代碼如下:

Class.forName("com.mysql.jdbc.Driver");//此處只是一個(gè)字符串

此時(shí)的好處是,我們的類中不再依賴具體的驅(qū)動(dòng)類,此時(shí)就算刪除mysql的驅(qū)動(dòng)jar包,依然可以編譯(運(yùn)行就不要想了,沒有驅(qū)動(dòng)不可能運(yùn)行成功的)。同時(shí),也產(chǎn)生了一個(gè)新的問題,mysql驅(qū)動(dòng)的全限定類名字符串是在java類中寫死的,一旦要改還是要修改源碼。解決這個(gè)問題也很簡單,使用配置文件配置。

以上只是說的解耦的一種思維,方便大家理解。

解耦的核心思想:若要減少代碼的耦合度,一定要盡量做到各個(gè)功能的代碼不能交叉編寫,編寫封閉的代碼。

解耦合

廣大程序猿同胞,經(jīng)常會(huì)看到“解耦合”,也有很多人,會(huì)用這個(gè)詞來裝X,但是,實(shí)際真正能理解的人,并不多。接下來,帶大家深入淺出的走一遍,如何解耦合。

首先,我們要知道,為什么要解耦合:通常,我們做一個(gè)項(xiàng)目,會(huì)用到很多基礎(chǔ)功能塊,比如xxx通信協(xié)議,xxxView等等,我們會(huì)把這種功能塊封裝成一個(gè)庫,如果這個(gè)庫,只能在這個(gè)指定的項(xiàng)目運(yùn)行,這就叫高耦合,這就導(dǎo)致了,如果下次再次遇到一個(gè)類似的項(xiàng)目,需要用到同樣功能的功能塊時(shí),你會(huì)要做很多重復(fù)工作。假設(shè),每次使用json時(shí),你都要對(duì)json庫進(jìn)行改造,那將會(huì)是一個(gè)晴天霹靂。

但是,事與愿違,有些情況,還真的不太好解耦。

這里,我們先舉個(gè)栗子,比如排序

一個(gè)排序功能,對(duì)于大部分比較初級(jí)的程序猿來說,可能會(huì)寫成這樣:

sort(ListIntegerlist)

這樣就導(dǎo)致了一個(gè)問題所在,這個(gè)方法只能排序int型數(shù)據(jù),如果下一個(gè)項(xiàng)目,需要用到對(duì)String進(jìn)行排序,那就很尷尬,感覺明明要成功了,但是又差一點(diǎn)。對(duì),就是差這一點(diǎn),就是代碼解耦的關(guān)鍵。

我們先要明確,我們需要做的是排序功能,在這個(gè)過程中,我們不可避免的需要使用2個(gè)數(shù)據(jù)的大小對(duì)比,而這個(gè)數(shù)據(jù),可能是任何數(shù)據(jù),也就是說,排序算法,我們是可以確定下來,做成不動(dòng)的庫,但是有一個(gè)數(shù)據(jù)大小匹配是我們無法做到的,或者說是庫的耦合點(diǎn),那怎么辦呢?

我們就讓使用我們這個(gè)功能塊的人,告訴我們就行啦。

下面,我們參考Android庫里面,有個(gè)排序的api

Collections.sort(ListTlist,ComparatorsuperT

這里,Comparator這個(gè)接口,就是使用者,需要實(shí)現(xiàn),并且傳遞進(jìn)去的接口。這樣做,這個(gè)排序功能塊就可以應(yīng)用在任何場(chǎng)合,達(dá)到一次開發(fā),受用終身的目的。是不是很神奇?

我們?cè)倥e個(gè)栗子,socket

我們?cè)陂_發(fā)時(shí),經(jīng)常會(huì)用到socket庫,而socket最常用,最常用的一個(gè)功能就是:“連接-發(fā)送數(shù)據(jù)-接收數(shù)據(jù)-斷開連接-回調(diào)結(jié)果”

所以,如果需要把這個(gè)流程,封裝成一個(gè)功能塊是很有意義的。

但是,這里有一個(gè)問題,是阻礙封裝的,就是"接收數(shù)據(jù)-斷開連接",socket讀取數(shù)據(jù)時(shí),是一個(gè)inputStream,是個(gè)流,也就是說,其實(shí),你并不知道,數(shù)據(jù)怎么樣才算接收完整/完畢

可能,有的協(xié)議,是通過頭2個(gè)字節(jié)來判斷整個(gè)數(shù)據(jù)長度

可能,有的協(xié)議是有幀頭,幀尾,轉(zhuǎn)義符來判斷整個(gè)數(shù)據(jù)長度

……

這讓我們很頭疼,那怎么解決了,既然無法知道的東西,就讓應(yīng)用程序來告訴你唄。和上面一樣,傳入一個(gè)協(xié)議實(shí)現(xiàn)唄:

publicinterfaceUnZipDataAction{

//返回null,表示未接收完全,繼續(xù)接收,返回完整的byte[]就認(rèn)為是已經(jīng)接收完畢,把結(jié)果返回給應(yīng)用,并且斷開連接

byte[]getRealData(byte[]recvData);ErrorCodegetErrorCode();}

這樣,我們就把“連接-發(fā)送數(shù)據(jù)-接收數(shù)據(jù)-斷開連接-回調(diào)結(jié)果”整

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論