第13條 使類和成員的可訪問性最小化

概要

1.使類和成員的可訪問性最小化的意義

2.類和成員的可訪問性類別

3.其他注意事項

4.最后的原則


一、使類和成員的可訪問性最小化的意義

1. 概念:信息隱藏(或者"封裝")

一個模塊對外部模塊隱藏其內(nèi)部數(shù)據(jù)和其他實現(xiàn)細節(jié),將它的API與它的實現(xiàn)細節(jié)清晰地隔離開來,模塊之間只通過API進行通信,其他模塊不需要知道該模塊的內(nèi)部工作情況。

2.?封裝的作用

(1) 有效的解除組成系統(tǒng)的各模塊之間的耦合關(guān)系,使得各個模塊可以獨立地開發(fā),測試,優(yōu)化,使用,理解和修改。

(2)?減輕程序員維護的負擔。維護的模塊的時候,只需要維護單個的模塊,不用考慮其它模塊的事情,只需要考慮模塊對外提供的API。

(3) 模塊復(fù)用,可以將模塊移植到其他系統(tǒng)(模塊拆分),重復(fù)使用

(4) 優(yōu)化方便,檢測性能的時候,可以確定出是哪個模塊的問題,只需要專門針對該模塊進行優(yōu)化

二、類和成員的幾種可訪問性

1.頂層類(非嵌套)和接口,有兩種訪問級別,包級私有和公有的

頂層類,如果是包級私有,只有該包中的類才能使用它

接口,如果是包級私有,只有該包中的類能實現(xiàn)它

package test.topclass;

??? class OneClass {

}

--------------------------------------

package test.topclass;

??? interface OneInterface {

}

----------------------------------------

package test.topclass;

public class TestClass implements OneInterface{
??? public static void main(String[] args) {
??????? OneClass one = new OneClass();
??? }
}

2.私有嵌套類(或者接口)

如果一個包級私有的頂層類(或者接口)只是在某一個類的內(nèi)部被用到,就應(yīng)該考慮使它成為唯一使用它的那個類的私有嵌套類(或者接口)。這樣可以將它的可訪問范圍從包中的所有類縮小到了使用它的那個類

package test.privateclass;

class TopClass {
??? private interface TopInterface {

??? }
???
??? private class UserClass {
??????? private TopInterface oneInterface = new TopInterface(){};
??????? private TopClass oneClass = new TopClass();
??? }
}

3.類成員(域,方法,嵌套類和嵌套接口),有四種可訪問級別

私有的(private) -- 只有在聲明該成員的頂層類內(nèi)部才可以訪問這個成員

包級私有的(package-private) -- 聲明該成員的包內(nèi)部的任何類都可以訪問這個成員。從技術(shù)上講,它被稱為"缺省(default)訪問級別",如果沒有為成員指定訪問修飾符,就采用這個訪問級別

受保護的(protected) -- 聲明該成員的類的子類可以訪問這個成員,并且,聲明該成員的包的內(nèi)部的任何類也可以訪問這個成員

公有的(public) -- 在任何地方都可以訪問該成員

訪問權(quán)限??????? 類?????????包????????子類????????其他包

public??????????????√???????????√?????????? √?????????????? √

protected????????√???????????√??????????? √???????????????×

default????????????√?????????? √????????????×???????????????×

private?????????????√????????????×???????????×????????????????×

對于接口的成員,只有一種訪問級別,公有的。(下面例子是錯誤的)

package test;

public interface OneInteface {
????private int ten = 10;
????private void add();
}

三、其他注意事項

1.實例域決不能是公有的

如果域是非final的,或者是一個指向可變對象的final引用,那么一旦使這個域成為公有的,就放棄了對存儲在這個域中的值進行限制的能力

2.靜態(tài)公共域只能為final修飾的基本類型或者final修飾的不可變類

假設(shè)常量構(gòu)成了類提供的整個抽象中的一部分,可以通過公有的靜態(tài)final域來暴露這些常量

package test.other;


public class PublicClass {
????public static final String STRING_HELLO="HELLO";

}

final修飾引用類型的變量:test.staticpublic

3.長度非零的數(shù)組總是可變的,可被修改的

package test.other;


public class PublicArray {
??? public static final int[] VALUES = { 1, 2, 3 };
??? private static final float[] VALUES_FLOAT = {1.2f,1.3f};

??? public static float[] getFloatArray(){
??? return VALUES_FLOAT;
??? }

??? public static void main(String[] args){
??? PublicArray.VALUES[0] = 10;
??? PublicArray.getFloatArray()[0] = 10.2f;
??????? System.out.println("--------VALUE----------");
??????? for(int value:VALUES) {
??????????? System.out.println(value+"");
??????? }
??????? System.out.println("--------VALUE_FLOAT----------");
??????? for(float valueFloat:VALUES_FLOAT) {
??????????? System.out.println(valueFloat+"");
??????? }
??? }
}



package test.other;

import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class PublicArrayTwo {
??? private static final int[] VALUES = { 1, 2, 3 };
??? private static final float[] VALUES_FLOAT = { 1.2f, 1.3f };

??? public static final List<int[]> values() {
??? return Collections.unmodifiableList(Arrays.asList(VALUES));
??? }

??? public static final float[] getFloatArray() {
??? return VALUES_FLOAT.clone();
??? }
}

package test.other;

import java.util.List;

public class TestPublicArrayTwo {
??? public static void main(String[] args) {
??????? List<int[]> pat = PublicArrayTwo.values();
??????? if(pat.size() > 0){
??????????? int[] publicArray = pat.get(0);
??????????? for(int i = 0; i < publicArray.length; i++){
??????????? int j = publicArray[i];
??????????? System.out.println(j);
??????????? }
??????? }
??????? System.out.println("------------------------------------------------");
??????? float[] oneFloat = PublicArrayTwo.getFloatArray();
??????? for(int i = 0; i < oneFloat.length; i++){
??????? System.out.println(oneFloat[i]);
??????? }
??? }
}

四、最后的原則

總而言之,你應(yīng)該始終盡可能地降低可訪問性。你在仔細地設(shè)計了一個最小的公有API之后,應(yīng)該防止把任何散亂的類、接口和成員變成API的一部分。除了公有靜態(tài)final域的特殊情形之外,公有類都不應(yīng)該包含公有域。并且要確保公有靜態(tài)final域所引用的對象都是不可變的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,333評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,491評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,263評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,946評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,708評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,409評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,939評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,774評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,209評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,641評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,872評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,650評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,958評論 2 373

推薦閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,717評論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,781評論 18 139
  • 模塊之間只通過API通信,其他的隱藏起來。降低耦合,獨立地開發(fā),測試,優(yōu)化 Access control ? pr...
    Jeanz閱讀 172評論 0 0
  • 一、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,282評論 0 16
  • 早上6:00,西安,安靜,美好
    藍色星空blue閱讀 159評論 0 0