第5章 隱藏實施過程
第5章 隱藏實施過程“進行面向?qū)ο蟮脑O(shè)計時,一項基本的考慮是:如何將發(fā)生變化的東西與保持不變的東西分隔開?!边@一點對于庫來說是特別重要的。那個庫的用戶(客戶程序員)必須能依賴自己使用的那一部分,并知道
第5章 隱藏實施過程
“進行面向?qū)ο蟮脑O(shè)計時,一項基本的考慮是:如何將發(fā)生變化的東西與保持不變的東西分隔開。”
這一點對于庫來說是特別重要的。那個庫的用戶(客戶程序員)必須能依賴自己使用的那一部分,并知道一旦新版本的庫出臺,自己不需要改寫代碼。而與此相反,庫的創(chuàng)建者必須能自由地進行修改與改進,同時保證客戶程序員代碼不會受到那些變動的影響。
為達到這個目的,需遵守一定的約定或規(guī)則。例如,庫程序員在修改庫內(nèi)的一個類時,必須保證不刪除已有的方法,因為那樣做會造成客戶程序員代碼出現(xiàn)斷點。然而,相反的情況卻是令人痛苦的。對于一個數(shù)據(jù)成員,庫的創(chuàng)建者怎樣才能知道哪些數(shù)據(jù)成員已受到客戶程序員的訪問呢?若方法屬于某個類唯一的一部分,而且并不一定由客戶程序員直接使用,那么這種痛苦的情況同樣是真實的。如果庫的創(chuàng)建者想刪除一種舊有的實施方案,并置入新代碼,此時又該怎么辦呢?對那些成員進行的任何改動都可能中斷客戶程序員的代碼。所以庫創(chuàng)建者處在一個尷尬的境地,似乎根本動彈不得。
為解決這個問題,Java推出了“訪問指示符”的概念,允許庫創(chuàng)建者聲明哪些東西是客戶程序員可以使用的,哪些是不可使用的。這種訪問控制的級別在“最大訪問”和“最小訪問”的范圍之間,分別包括:public,“友好的”(無關(guān)鍵字),protected以及private。根據(jù)前一段的描述,大家或許已總結(jié)出作為一名庫設(shè)計者,應(yīng)將所有東西都盡可能保持為“private”(私有),并只展示出那些想讓客戶程序員使用的方法。這種思路是完全正確的,盡管它有點兒違背那些用其他語言(特別是C)編程的人的直覺,那些人習慣于在沒有任何限制的情況下訪問所有東西。到這一章結(jié)束時,大家應(yīng)該可以深刻體會到Java訪問控制的價值。
然而,組件庫以及控制誰能訪問那個庫的組件的概念現(xiàn)在仍不是完整的。仍存在這樣一個問題:如何將組件綁定到單獨一個統(tǒng)一的庫單元里。這是通過Java的package(打包)關(guān)鍵字來實現(xiàn)的,而且訪問指示符要受到類在相同的包還是在不同的包里的影響。所以在本章的開頭,大家首先要學習庫組件如何置入包里。這樣才能理解訪問指示符的完整含義。
5.1 包:庫單元
我們用import關(guān)鍵字導入一個完整的庫時,就會獲得“包”(Package)。例如:
import java.util.*;
它的作用是導入完整的實用工具(Utility)庫,該庫屬于標準Java開發(fā)工具包的一部分。由于Vector位于java.util里,所以現(xiàn)在要么指定完整名稱“java.util.Vector”(可省略import語句),要么簡單地指定一個“Vecto