公眾號(hào):mywangxiao
及時(shí)發(fā)布考試資訊
分享考試技巧、復(fù)習(xí)經(jīng)驗(yàn)
新浪微博 @wangxiaocn關(guān)注微博
聯(lián)系方式 400-18-8000
一、類(lèi)隱藏的基本建議
雖然在JAVA語(yǔ)言中要實(shí)現(xiàn)類(lèi)的隱藏非常簡(jiǎn)單,只需要通過(guò)三個(gè)關(guān)鍵字即可以完成。但是在大部分情況下,讓JAVA程序員感到疑惑的是,在什么時(shí)候該把什么類(lèi)隱藏。確實(shí),在JAVA開(kāi)發(fā)語(yǔ)言平臺(tái)中,對(duì)于什么類(lèi)需要隱藏,什么類(lèi)不需要隱藏,往往沒(méi)有很?chē)?yán)格的要求。為此程序開(kāi)發(fā)人員需要根據(jù)自己的工作經(jīng)驗(yàn)來(lái)進(jìn)行判斷。而即使有一定程序開(kāi)發(fā)經(jīng)驗(yàn)的員工,也不一定能夠在這個(gè)問(wèn)題上給出很好的答案。公說(shuō)公有理,婆說(shuō)婆有理,為此很難有一個(gè)統(tǒng)一的標(biāo)準(zhǔn)。筆者下面幾個(gè)建議,也是對(duì)自己這幾年來(lái)JAVA開(kāi)發(fā)工作的總結(jié)。希望這些建議能夠幫助大家解惑。
1、不同模塊之間的類(lèi)要相互隱藏。現(xiàn)在不少應(yīng)用系統(tǒng),為了提高開(kāi)發(fā)效率,都提出了模塊化的設(shè)計(jì)理念。如最近比較流行的ERP系統(tǒng),如果按模塊來(lái)進(jìn)行設(shè)計(jì)的話,則在開(kāi)發(fā)時(shí)不同的人員可以負(fù)責(zé)各自的模塊,而互不干涉。在ERP系統(tǒng)出售的時(shí)候,也可以按模塊來(lái)進(jìn)行出售,因?yàn)楦鱾€(gè)模塊的功能是相對(duì)獨(dú)立的。當(dāng)然這只是從管理層面來(lái)說(shuō)模塊化設(shè)計(jì)的重要性,不過(guò)這不是我們今天要談?wù)搩?nèi)容的重點(diǎn)。今天要談的是,如果應(yīng)用系統(tǒng)按模塊化來(lái)進(jìn)行設(shè)計(jì),那么不同模塊之間的內(nèi)如何實(shí)現(xiàn)隱藏呢?其實(shí)很簡(jiǎn)單。如供應(yīng)商基本信息維護(hù)、供應(yīng)商進(jìn)貨單、應(yīng)付帳款分屬于三個(gè)不同的模塊,分別為采購(gòu)管理、庫(kù)存管理與應(yīng)收應(yīng)付管理?,F(xiàn)在在設(shè)計(jì)應(yīng)收應(yīng)付這個(gè)模塊時(shí)其中有一個(gè)生成應(yīng)付帳款的類(lèi),其需要用到采購(gòu)管理模塊中供應(yīng)商的信息(付款條件等等)、倉(cāng)庫(kù)管理模塊中的供應(yīng)商進(jìn)貨單據(jù)(產(chǎn)品編號(hào)、數(shù)量、到貨日期等等),然后才能夠生成準(zhǔn)確的應(yīng)付帳款。那么在應(yīng)用程序設(shè)計(jì)的時(shí)候該如何實(shí)現(xiàn)呢?是在那個(gè)應(yīng)付帳款作業(yè)對(duì)應(yīng)的類(lèi)中直接從數(shù)據(jù)庫(kù)中去查詢這些信息嗎,又或者去修改采購(gòu)模塊中對(duì)應(yīng)的類(lèi)來(lái)實(shí)現(xiàn)?這雖然都可以達(dá)到預(yù)定的目的,但是都不是上上之策。個(gè)人認(rèn)為,最好的方法就是程序開(kāi)發(fā)人員先設(shè)計(jì)一個(gè)類(lèi)(如Vender類(lèi)),這個(gè)類(lèi)會(huì)返回供應(yīng)商編號(hào)、付款條件等信息。然后應(yīng)付帳款作業(yè)中的類(lèi)就直接調(diào)用這個(gè)類(lèi)獲取需要的信息。一方面可能很多地方都需要用到這些信息,如果每次需要的時(shí)候都利用SQL代碼來(lái)獲取這些信息的話,那么代碼量也會(huì)很大。相反直接調(diào)用類(lèi)來(lái)實(shí)現(xiàn)這些信息反而更加的方面。另一方面,這個(gè)Vender類(lèi)對(duì)于其他類(lèi)是隱藏的。也就是說(shuō),其他類(lèi)只能夠通過(guò)預(yù)定義的接口向這個(gè)類(lèi)傳遞參數(shù)并直接引用其返回的結(jié)果,而不能夠修改類(lèi)內(nèi)部的元素。如此即使其他有十幾個(gè)類(lèi)或者應(yīng)用程序需要調(diào)用這個(gè)類(lèi)的時(shí)候,其只要輸入的參數(shù)相同,則其返回的結(jié)果也就相同。那么其他類(lèi)在引用返回結(jié)果的時(shí)候,就不用擔(dān)心不兼容了。所以,應(yīng)用程序的模塊化設(shè)計(jì)促使JAVA程序要實(shí)現(xiàn)類(lèi)與類(lèi)之間的隱藏;同時(shí)JAVA類(lèi)相互之間隱藏的特性也方便了應(yīng)用程序的模塊化設(shè)計(jì)。
2、數(shù)據(jù)類(lèi)型類(lèi)與其他類(lèi)之間需要實(shí)現(xiàn)隱藏。在任何一個(gè)應(yīng)用程序開(kāi)發(fā)過(guò)程中,都需要根據(jù)企業(yè)的需要設(shè)計(jì)一些比較有針對(duì)性的數(shù)據(jù)類(lèi)型。因?yàn)楣饪繎?yīng)用程序所提供的那些數(shù)據(jù)類(lèi)型往往不能夠滿足程序開(kāi)發(fā)人員的需要。如需要設(shè)計(jì)一些數(shù)組、記錄等等數(shù)據(jù)類(lèi)型。但是在設(shè)計(jì)這些數(shù)據(jù)類(lèi)型的時(shí)候,程序人員就需要了一個(gè)難題。如現(xiàn)在在開(kāi)發(fā)ERP系統(tǒng)的過(guò)程中,多個(gè)模塊(每個(gè)模塊由不同的程序員負(fù)責(zé))都需要用到同一個(gè)記錄數(shù)據(jù)類(lèi)型。那么是每個(gè)程序員都設(shè)計(jì)一個(gè)記錄類(lèi)型的數(shù)據(jù)類(lèi)型,還是共用同一個(gè)數(shù)據(jù)類(lèi)型呢?如果各管各的,就需要建立多個(gè)記錄類(lèi)型的數(shù)據(jù)類(lèi)型,管理起來(lái)比較麻煩,對(duì)后續(xù)升級(jí)也會(huì)遇到障礙。而如果大家共用一個(gè)記錄類(lèi)型的數(shù)據(jù)類(lèi)型,大家又擔(dān)心其他程序人員不小心修改了這個(gè)數(shù)據(jù)類(lèi)型而給他們?cè)斐闪寺闊?。這之間難道就沒(méi)有和平的共存方式了呢?其實(shí),在應(yīng)用程序開(kāi)發(fā)的過(guò)程中可以認(rèn)為的將應(yīng)用程序開(kāi)人人員分為數(shù)據(jù)類(lèi)型創(chuàng)者者與業(yè)務(wù)邏輯開(kāi)發(fā)者。然后數(shù)據(jù)類(lèi)型開(kāi)發(fā)者可以根據(jù)其他開(kāi)發(fā)人員的需要?jiǎng)?chuàng)建一些定義數(shù)據(jù)類(lèi)型的類(lèi),這些類(lèi)的話對(duì)于其他程序開(kāi)發(fā)人員開(kāi)發(fā)的類(lèi)是隱藏的。也就是說(shuō),其他類(lèi)不能夠?qū)@個(gè)數(shù)據(jù)類(lèi)型進(jìn)行修改。那么即可以提高這些數(shù)據(jù)類(lèi)型的利用率,而且也可以保證其他類(lèi)可以以固定的格式引用這些類(lèi)。
3、業(yè)務(wù)層與表示層之間的類(lèi)要相互隱藏。利用過(guò)J2EE開(kāi)發(fā)平臺(tái)的人肯定知道,在開(kāi)發(fā)應(yīng)用程序的時(shí)候,業(yè)務(wù)邏輯層與表示層之間是相互獨(dú)立的。業(yè)務(wù)邏輯層主要實(shí)現(xiàn)一些負(fù)責(zé)的運(yùn)算,如物料需求計(jì)劃運(yùn)算。而表示層的話只負(fù)責(zé)一些具體的顯示。如通過(guò)瀏覽器客戶端來(lái)顯示結(jié)果還是通過(guò)軟件窗口來(lái)顯示運(yùn)算結(jié)果。雖然客戶端所采用的方式不同,但是其內(nèi)部的運(yùn)算是相同的。此時(shí)最好把實(shí)現(xiàn)業(yè)務(wù)邏輯層的類(lèi)與實(shí)現(xiàn)表示層的類(lèi)相互隱藏起來(lái)。因?yàn)樵趯?shí)際開(kāi)發(fā)過(guò)程中,他們往往是由不同的程序開(kāi)發(fā)人員完成的。為了避免不同程序開(kāi)發(fā)人員之間的相互干擾,避免表示層的開(kāi)發(fā)人員無(wú)意中修改了業(yè)務(wù)邏輯層的JAVA類(lèi),就必須要把業(yè)務(wù)邏輯層的類(lèi)隱藏起來(lái)。也就是說(shuō),表示層開(kāi)發(fā)人員只需要知道業(yè)務(wù)邏輯層的類(lèi)需要哪些參數(shù)、能夠以什么樣的形式返回結(jié)果即可。然后表示層的類(lèi)在調(diào)用業(yè)務(wù)邏輯層中的類(lèi)的時(shí)候,只需要按照要求輸入?yún)?shù)、按照規(guī)則獲取結(jié)果即可,而不需要關(guān)注其業(yè)務(wù)邏輯層類(lèi)內(nèi)部的實(shí)現(xiàn)機(jī)制,從而減輕了表示層開(kāi)發(fā)人員的工作量。同時(shí)也避免了業(yè)務(wù)層開(kāi)發(fā)人員對(duì)這個(gè)類(lèi)進(jìn)行修改,從而其他的應(yīng)用程序開(kāi)發(fā)人員可以以同一種方式來(lái)引用這些類(lèi)。
4、如果某個(gè)業(yè)務(wù)邏輯還不怎么完善時(shí),要執(zhí)行隱藏。在應(yīng)用程序開(kāi)發(fā)的過(guò)程中,可能某些業(yè)務(wù)邏輯暫時(shí)沒(méi)有很好的解決方案,但是需要的參數(shù)或者返回的結(jié)果是確定的。此時(shí)可以把這個(gè)業(yè)務(wù)邏輯建立一個(gè)的類(lèi),并對(duì)其他類(lèi)進(jìn)行隱藏。如此的話,當(dāng)出現(xiàn)更好的解決方案之后,就可以直接更改這個(gè)類(lèi)中的業(yè)務(wù)邏輯。由于類(lèi)中成員對(duì)于其他程序人員是隱藏的,為此對(duì)類(lèi)中的處理機(jī)制進(jìn)行更改并不會(huì)影響到其他人員開(kāi)發(fā)的應(yīng)用程序。他們只關(guān)心你能夠在最短時(shí)間內(nèi)獲得準(zhǔn)確的結(jié)果。為此在遇到這種情況時(shí),最好把類(lèi)與其他的類(lèi)執(zhí)行隱藏。
可見(jiàn),哪些類(lèi)需要相互隱藏可能判斷起來(lái)比較復(fù)雜。但是有一個(gè)普遍適用的原則,就是如果一個(gè)類(lèi)有不同的程序人員需要引用。如用戶A設(shè)計(jì)了一個(gè)統(tǒng)計(jì)應(yīng)收帳款余額的類(lèi),用戶B與C,包括用戶A都需要調(diào)用這個(gè)類(lèi)。那么這個(gè)類(lèi)就最好進(jìn)行隱藏。防止其他類(lèi)在調(diào)用這個(gè)類(lèi)的時(shí)候,不小心修改了其內(nèi)部的實(shí)現(xiàn)方式。這會(huì)對(duì)其他用戶調(diào)用這個(gè)類(lèi)產(chǎn)生不利影響。
二、實(shí)現(xiàn)JAVA類(lèi)隱藏的三個(gè)關(guān)鍵字
之所有要實(shí)現(xiàn)JAVA類(lèi)隱藏,主要是讓任何程序開(kāi)發(fā)人員都無(wú)法觸及他們不應(yīng)該初期的部分(如業(yè)務(wù)邏輯或者數(shù)據(jù)類(lèi)型的內(nèi)部操作)。雖然項(xiàng)目管理員可能在程序開(kāi)發(fā)過(guò)程中多次告誡團(tuán)隊(duì)成員不要直接操作其他開(kāi)發(fā)人員所設(shè)計(jì)類(lèi)中的成員。但是如果缺乏一定的控制手段,這些事情往往會(huì)在有意無(wú)意中發(fā)生。為此需要采取一些強(qiáng)制的手段來(lái)防止這些情況的發(fā)生。而且這些事現(xiàn)方式必須簡(jiǎn)單,不能夠太過(guò)于復(fù)雜。在JAVA語(yǔ)言平臺(tái)中,就提供了Public、private、protected三個(gè)關(guān)鍵字來(lái)實(shí)現(xiàn)對(duì)類(lèi)的隱藏與控制。
這些關(guān)鍵字決定了類(lèi)或者類(lèi)中的成員是否對(duì)其他類(lèi)是隱藏的,能否被其他類(lèi)進(jìn)行操作與修改。如public關(guān)鍵字表示緊隨其后的元素對(duì)任何人都是可用的,可以被任何人所修改。而關(guān)鍵字Private則表示除了類(lèi)創(chuàng)建者和這個(gè)類(lèi)型的內(nèi)部方法之外的任何人都不能夠進(jìn)行訪問(wèn)。而關(guān)鍵Protected的作用跟Private類(lèi)似,只是其是作用在繼承中的。
可見(jiàn)在JAVA程序開(kāi)發(fā)中,要實(shí)現(xiàn)類(lèi)的隱藏是很簡(jiǎn)單的,也是JAVA程序員必須要掌握的一項(xiàng)基本功。而其難度就在于在適當(dāng)?shù)臅r(shí)候?qū)崿F(xiàn)類(lèi)和類(lèi)中成員的隱藏。這就要程序員在程序開(kāi)發(fā)過(guò)程中好好琢磨了。上面提到的一些建議可供大家做參考。
編輯推薦
JAVA認(rèn)證考試報(bào)考指南 / 更多JAVA考試資料
(責(zé)任編輯:xy)