論Java訪問許可權控制的重要性

沉默王二發表於2018-12-06

論Java訪問許可權控制的重要性
人在什麼面前最容易失去抵抗力?

美色,算是一個,比如說西施的貢獻薄就是忍辱負重、以身報國、助越滅吳;金錢,算是另外一個,我們古人常說“錢乃身外之物,生不帶來死不帶去”,但我們又都知道“有錢能使鬼推磨”。

除去美色和金錢,我認為還有一個,就是讀者的認可——“二哥,你的文章真的很棒,我特別喜歡。希望能多多更新Java基礎知識,真的是受益良多,就好像是在讀王小波的散文,但又學了程式設計!”——你說,收到讀者這樣暖暖的評語,還需要美色和金錢?“兩者皆可拋”嘛。

這篇文章主要介紹一下Java的訪問許可權控制。

01 訪問許可權控制的重要性

舒淇曾說過這樣一句令人感到震撼後又虎軀一震的話:“我要把我曾經脫下的衣服一件一件的穿回來!”如今,她做到了——通過自己的努力,不僅得到了觀眾的認可,得了很多大獎,還收穫了幸福。儘管,真的是儘管,還有一些“憶往昔崢嶸歲月稠”的朋友在電腦硬碟的深處留存了一些舒淇早年的珍藏版照片。

我扯這個例子主要為了證明一句話——訪問控制(或隱藏具體實現)與“最初的實現並不恰當”有關——如果舒淇當初那些照片的許可權不是那麼公開化的話,那現在就可以私自燒燬了;或者換一種出道方式;然而沒有如果了。

在你最初的程式設計生涯中,不知道你是否創作過下面這樣“優秀”的程式碼,就像程式清單1-1那樣。

程式清單1-1:

public class NiubiUtil {
	public static Date getNextDay() {
		long millis = 24 * 60 * 60 * 1000;
		try {
			Thread.sleep(millis);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		return new Date(System.currentTimeMillis());
	}
}
複製程式碼

本來你這些程式碼只是自己寫著玩呢,誰知道被一個叫小二哥的同事不經考量地呼叫了。這一呼叫不要緊,小二哥的程式碼真的活活地等了一整天——產品經理小王老師某一天心血來潮非要測試小二哥的程式碼,然後點了檢視下一天的按鈕,程式真的在那靜靜地等著,直到下一天真的來臨。

後果是,小王老師為了安撫使用者們躁動的情緒把小二哥直接拉出去祭天了;你躲在角落裡瑟瑟發抖,心裡默默唸叨了句話——“小二哥,你走好,兄弟真的對不住了”。

一場血淋漓的慘案啊!只因為Java訪問許可權控制的使用不當——該private的方法,結果失誤寫成了public——論訪問許可權控制的重要性。

02 為什麼需要訪問許可權控制

我已經在Java程式設計的道路上混跡了多年,自然也寫過無數曾經看起來那麼“優秀”的程式碼。隨著時間的推移,再回首過往的那些程式碼時,總有一種“這真的出自我手?”的疑問。

這種疑問包含兩層意思,一層是感慨真的寫得好,就好像年老時的李白看見自己年少時寫的《望廬山瀑布》:“日照香爐生紫煙,遙看瀑布掛前川;疑是銀河落九天,飛流直下三千尺。”——喲,老子年輕時寫得也不賴啊。

另外一層是感慨真的寫得差,比如說程式清單1-1,往事不堪回首啊,只能都隨風,都隨風,都隨風而去!

對於這些寫得很差的程式碼,我每次看見都想再修改一次,期待她更可讀、更易理解、更具可維護性;但在美好的願景下,也存在著巨大的壓力,因為有好多其他的地方引用了要修改的程式碼,牽一髮而動全身啊。

在變與不變的過程中,我發現——訪問許可權控制真的太重要了。在寫程式碼的過程中,我們需要儘量遵循這樣一個原則——除了那些必須public的方法,儘量把其他方法定義為private。這樣做的好處是,在重構private方法的時候不必再擔驚受怕,因為它們不會被類外部訪問到。

03 protected許可權修飾符是用來幹嘛的

我們知道,public許可權修飾符使類的一切方法和屬性對外可見;private許可權修飾符使類的一切方法和屬性只對內部可見;那麼protected許可權修飾符呢?

假如有一個叫王二的傢伙,他有三個屬性,分別是私生活、外在形象和被保護的財產,就像程式清單3-1那樣。

程式清單3-1:

public class Wanger {
	
	// 私生活
	private String life;
	
	// 外在形象
	public String image;
	
	// 被保護的財產
	protected String money;
}
複製程式碼

王二生了一個孩子叫王小二,就像程式清單3-2那樣。

程式清單3-2:

public class Wangxiaoer extends Wanger{
	@Override
	public String toString() {
		return "可以繼承的財產:" + money + ";塑造的人設:" + image + ";得不到的私生活:";
	}
}
複製程式碼

王小二可以繼承到王二的財產money(據說王二在王小二出生的第一個月為其存了100,以後每個月的利率為12%,現在存款是3758.17,你知道王小二現在多大了嗎?),也可以模仿一點父親的外在形象image,但卻不能按照父親的私生活方式生活。

注意到三個許可權修飾符的區別了嗎?

protected可以保護王二的財產順利地繼承到王小二那裡,外界的人是訪問不到的;public不安全,因為不僅王小二可以繼承訪問,外界其他人也可以訪問;private太私有化,不僅外界訪問不到,王小二也繼承不到。

04 總結

訪問許可權控制的兩個重要作用:第一是為了防止外界觸碰到不該觸碰的地方(private修飾的成員變數或者方法);第二是讓類的設計者可以更改內部(private修飾的成員變數或者方法)的工作方式,而不必擔心有沒有對外界造成干擾。


喜歡就點贊評論,因為你的參與是我在寫作道路上的最強動力。

相關文章