Effective Java讀書筆記 第四章 類與接口

  1. 盡可能的讓類或者成員不被外接訪問

    單一職責(zé),高內(nèi)聚低耦合,降低類被修改的風(fēng)險(xiǎn);

  2. 類具有共有的靜態(tài)finnal數(shù)組域 或者返回這種數(shù)組域的方法,總是錯(cuò)誤的

    public class Test {
      public static final List<String> list=new ArrayList<>();
    }  
    

    這樣的代碼容易讓外界修改 list中的內(nèi)容
    兩種辦法

    1. 增加一個(gè)共有的不可變列表 復(fù)制其中的內(nèi)容
      public class Test {
      private static final List<String> list=new ArrayList<>();
      public static final List<String> copys= Collections.copy(list,copys);
      }
    2. 增加一個(gè)公有的方法,返回他的clone;
  3. 在公有類中 我們經(jīng)常定義一個(gè)存儲(chǔ)數(shù)據(jù)的對(duì)象

    public class Test{
      public String a;
      public String b;
    }
    

    堅(jiān)持面向?qū)ο蟮乃枷?應(yīng)該給與封裝get set方法
    以便于后期需要想要改變內(nèi)部表示時(shí)進(jìn)行隔離

    好處是一旦需要更改,可以靈活的更改(內(nèi)部重載或者更改實(shí)現(xiàn)),
    壞處是增加了方法 在Android中有方法數(shù)限制
    綜合方案:對(duì)于JavaBean內(nèi)部,使用成員變量的時(shí)候,可以在內(nèi)部直接訪問,外部訪問必須進(jìn)過get set方法,這樣的話,因?yàn)槭窃趦?nèi)部訪問的,所以需要更改的時(shí)候很容易找到,同時(shí)也減少了不必要方法數(shù)/調(diào)用的開銷;

  4. 不可變類如果進(jìn)行多次變化,提供一個(gè)新的方法

    String不可變,提供了一個(gè)配套的變化類StringBuilder,方便多次進(jìn)行字符串拼接并且性能可靠;

  5. 不要為每一個(gè)get方法提供set方法,除非有很好的理由讓類變成可變類,否則就是不可變的類,

    1. 不可變類有很多優(yōu)點(diǎn),節(jié)省內(nèi)存,線程安全省資源,但是有一個(gè)缺點(diǎn),在特定情況下存在可能的性能問題(如String一直被+連接時(shí)生成大量的String對(duì)象,解決辦法是提供StringBuilder來構(gòu)建更加多變的類)
  6. 如果類是可變的,也要盡量降低他的可變性,除非有非常強(qiáng)烈的理由把這個(gè) 方法/字段 變成非final的,否則每個(gè)方法/字段 都應(yīng)該是final

  7. 復(fù)合優(yōu)于繼承:應(yīng)該用復(fù)合和轉(zhuǎn)發(fā)機(jī)制

    1. 復(fù)合轉(zhuǎn)發(fā)機(jī)制:A類中包含B類,調(diào)用A類的方法中,轉(zhuǎn)發(fā)調(diào)用B類方法,并且在中間插入某些操作
    2. 繼承:A類繼承B類,調(diào)用A類方法,轉(zhuǎn)發(fā)調(diào)用super,并且在中間插入某些操作(Activity生命周期方法全都是如此)
    3. 包裝類不適合與回調(diào),因?yàn)榛卣{(diào)對(duì)象提供的引用對(duì)象是其自身,并不是其包裝類,導(dǎo)致包裝類的方法失效....
    4. 只有當(dāng)A真正的是B的子類的時(shí)候,才能使用繼承,B確實(shí)是A,否則 應(yīng)該是復(fù)合的關(guān)系
  8. 要么為繼承設(shè)計(jì),并提供詳細(xì)的說明文檔,要么就禁止繼承

     好的API應(yīng)該描述一個(gè)給定的方法做了什么工作
    
  9. 接口優(yōu)于抽象類

    1. 現(xiàn)有的類很容易被擴(kuò)展,實(shí)現(xiàn)新的接口,而單繼承特性讓它很難繼承抽象類

    2. 接口是提供擴(kuò)展功能 的理想選擇

    3. 接口允許我們構(gòu)建非層次性結(jié)構(gòu),可以讓兩者毫無關(guān)聯(lián)的在一起,如果用抽象類,隨著需求的增大,可能會(huì)導(dǎo)致更加臃腫,導(dǎo)致組合爆炸

    4. 接口雖然不允許有實(shí)現(xiàn),但是可以給每一個(gè)導(dǎo)出的接口寫一個(gè)抽象的骨架實(shí)現(xiàn),把接口和抽象類的優(yōu)點(diǎn)結(jié)合起來(類似于上面的包裝類),接口負(fù)責(zé)定義類型,骨架類負(fù)責(zé)實(shí)現(xiàn)()
      例如:各種Abstract開頭的類,比如AbstractList,AbstractMap實(shí)現(xiàn)了接口的一些通用方法,方便子類進(jìn)行更好的編碼:
      如果一個(gè)接口有多個(gè)方法是子類都共有的,可以編寫一個(gè)AbstractXXX骨架類,實(shí)現(xiàn)共有方法,子類便于更好的編碼;

    5. 抽象類的修改比接口的修改容易的多,抽象類可以任意增加具體的實(shí)現(xiàn)方法而不用修改子類,接口不行,接口一旦被公開,想再增加方法需要更改所有的實(shí)現(xiàn)類,成本極高

  10. 接口只應(yīng)該用于定義類型

    1. 常量接口(接口中只包含一些具體的常量字段,不包含抽象方法),是錯(cuò)誤的(還記得V影院的BaseActivity實(shí)現(xiàn)的接口嗎 直接把常量都定義到一個(gè)接口里面去了)
    2. 靜態(tài)工具類可以代替常量接口,并且靜態(tài)導(dǎo)入讓使用更加方便
  11. 類層次優(yōu)于標(biāo)簽類

    1. 一種類負(fù)責(zé)實(shí)例化好幾種不同的對(duì)象(形狀類 實(shí)例化成圓形/正方形/三角形),導(dǎo)致內(nèi)部代碼臃腫,應(yīng)該分成多個(gè)類分別實(shí)例化
    2. 用單個(gè)的類去區(qū)分功能,好過于用一個(gè)類去管理實(shí)例變化
  12. 用函數(shù)對(duì)象表示策略

    實(shí)際上就是我們Android常用的匿名內(nèi)部類,比如點(diǎn)擊事件等等,
    回調(diào)機(jī)制, 抽象方法

  13. 優(yōu)先考慮靜態(tài)成員類

    1. 四種嵌套類:靜態(tài)成員類,非靜態(tài)成員類,匿名類,局部類,后面三種都稱之為內(nèi)部類
    2. 非靜態(tài)內(nèi)部類存在一個(gè)this的外部類引用,
    3. 如果成員類不要求訪問外部實(shí)例,則始終加上static修飾符

總結(jié):

  1. 編碼時(shí)刻遵循高內(nèi)聚,低耦合,盡量減少外界對(duì)類的修改,并且對(duì)類的修改入口進(jìn)行封裝(比如set,get),便于后期擴(kuò)展
  2. 復(fù)合(組合)優(yōu)于繼承,繼承破壞了封裝性和靈活性,并且使得類臃腫,如果非得用,可以用復(fù)合+轉(zhuǎn)發(fā)機(jī)制代替繼承;
  3. 接口優(yōu)于抽象類,道理同上,如接口中有公共的實(shí)現(xiàn)方法,考慮編寫Abstract骨架類,讓子類更少的編寫代碼,復(fù)用邏輯;
  4. 類層次優(yōu)于標(biāo)簽類(類中根據(jù)各種條件去進(jìn)行各種操作的類),用類去分層而不是用if-else邏輯(簡(jiǎn)單工廠模式+類分層可以代替標(biāo)簽類)
  5. 回調(diào),抽象方法
  6. 內(nèi)部類盡量加上static,比如ViewHolder,
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市懈万,隨后出現(xiàn)的幾起案子锅减,更是在濱河造成了極大的恐慌瑞躺,老刑警劉巖印衔,帶你破解...
    沈念sama閱讀 222,729評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件麻裳,死亡現(xiàn)場(chǎng)離奇詭異甥桂,居然都是意外死亡蚊夫,警方通過查閱死者的電腦和手機(jī)银择,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門多糠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人浩考,你說我怎么就攤上這事夹孔。” “怎么了析孽?”我有些...
    開封第一講書人閱讀 169,461評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵搭伤,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我袜瞬,道長(zhǎng)闷畸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評(píng)論 1 300
  • 正文 為了忘掉前任吞滞,我火速辦了婚禮佑菩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘裁赠。我一直安慰自己殿漠,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評(píng)論 6 398
  • 文/花漫 我一把揭開白布佩捞。 她就那樣靜靜地躺著绞幌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪一忱。 梳的紋絲不亂的頭發(fā)上莲蜘,一...
    開封第一講書人閱讀 52,736評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音帘营,去河邊找鬼票渠。 笑死,一個(gè)胖子當(dāng)著我的面吹牛芬迄,可吹牛的內(nèi)容都是我干的问顷。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼杜窄!你這毒婦竟也來了肠骆?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,124評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤塞耕,失蹤者是張志新(化名)和其女友劉穎蚀腿,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扫外,經(jīng)...
    沈念sama閱讀 46,657評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡唯咬,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了畏浆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片胆胰。...
    茶點(diǎn)故事閱讀 40,872評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖刻获,靈堂內(nèi)的尸體忽然破棺而出蜀涨,到底是詐尸還是另有隱情,我是刑警寧澤蝎毡,帶...
    沈念sama閱讀 36,533評(píng)論 5 351
  • 正文 年R本政府宣布厚柳,位于F島的核電站,受9級(jí)特大地震影響沐兵,放射性物質(zhì)發(fā)生泄漏别垮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評(píng)論 3 336
  • 文/蒙蒙 一扎谎、第九天 我趴在偏房一處隱蔽的房頂上張望碳想。 院中可真熱鬧,春花似錦毁靶、人聲如沸胧奔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽龙填。三九已至,卻和暖如春拐叉,著一層夾襖步出監(jiān)牢的瞬間岩遗,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工凤瘦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留宿礁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,304評(píng)論 3 379
  • 正文 我出身青樓廷粒,卻偏偏與公主長(zhǎng)得像窘拯,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子坝茎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評(píng)論 2 361

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