相關讀書筆記列表
NO.12 使類和成員的可訪問能力最小化
好的模組設計應該盡最大可能封裝好自己的內部資訊,這樣可以把模組之間的耦合程度降到最低。開發得以並行,無疑這將加快開發的速度,便於系統地維護。Java中通過存取控制符來解決這個問題。
- public表示這個類在任何範圍都可用。
- protected表示只有子類和包內的類可以使用
- private-package(default)表示在包內可用
- private表示只有類內才可以用
在設計的時候應該儘可能的使每一個類或者成員不被外界所訪問。在設計一個類的時候應該盡量的按照4321得順序設計。如果一個類只是被另一個類使用,那麼應該考慮把它設計成這個類的內部類。通常
public的類不應該有public得欄位,不過我們通常會用一個類來定義所有的常量,這是允許的。不過必須保證這些欄位要麼是基礎資料型別 (Elementary Data Type)要麼引用指向的對象是不可修改的。不然他們將可能被修改。例如下面的定義中data就是不合理的,其他人可以改變數組中的內容,有安全性漏洞,後面兩個沒有問題。
public class Con<br />{<br /> public static final int[] data = {1,2,3};// it is bad<br /> public static final String hello = "world";<br /> public static final int i = 1;<br />}
解決daa安全隱患的方法有兩種:
①將公有方法替換為一個私人數組,以及一個公有的非可變列表
private static final Type[] PRIVATE_VALUES = {...};<br />public static final List VALUES = Collections.unmodifiableLis(Arrays.asList(PRIVATE_VALUES));
②把公有的數組替換為一個公有的方法,它返回私人數組的一份拷貝
private static final Type[] PRIVATE_VALUES = {...};<br />public static final Type[] values(){<br /> return (Type[])PRIVATE_VALUES.clone();<br />}
總之,應該防止把任何雜散的累介面和成員變成API的一部分,除了公有靜態final域的特殊情形之外,公有類不應該包含公有域,並且確保有靜態final域所引用的對性是不可變的。
NO.13 支援非可變性