五項最佳實踐讓您的Java代碼免受bug困擾

齊萬山 8年前發布 | 7K 次閱讀 Java Java開發

牢記以下各項基本原則,能夠幫助大家盡可能減少代碼中的bug。

Java編程語言的人氣自然無需質疑,從Web應用到Android應用,這款語言已經被廣泛用于開發各類應用及代碼中的復雜功能。

不過在編寫代碼時,bug永遠是困擾每一位從業者的頭號難題。在今天的文章中,我們將分享五貢最佳實踐,希望幫助大家更為輕松地減少Java開發中的bug數量。

原則一:不要依賴初始化

在Java中,開發者常常依賴構造函數進行對象初始化。不過這其實是一種常見誤區。我們完全可以在無需調用構造函數的情況下,通過多種方式實現對象分配。

下面來看幾種常用方式:

? 大家可以將所有變量聲明為私有。要訪問該類外的對象,大家可使用GET與SET方法。

? 對每個對象,編寫一個新的私有boolean變量并對其進行初始化。

? 編寫一個非構造函數類,其將確保每個對象會在接受調用之前進行初始化。

原則二:保護類、方法與變量

在代碼當中,類、方法與變量分為私有與公共兩類。私有類無法輕松進行訪問,這使其成為代碼中的高安全性點。不過公共方法與變量則易于方法,也因此常常成為攻擊突破口。因此,請盡可能限制其范圍。

請記住,只在必要時開放類、方法與變量。

原則三:永遠對范圍進行預定義

大多數開發者完全依賴于軟件包自身的范圍設定,事實上我們應當堅持對代碼范圍進行預定義。很多類本身并非完全封閉,這意味著攻擊者能夠對其施以攻擊。黑客可以利用單一漏洞插入自己的類,進而從代碼中提取敏感信息。JVM在默認情況下即不會封閉,不過允許大家在該軟件包內進行類封閉。

原則四:避免使用內部類

一般來講,開發者會在同一軟件包內其它類需要時使用內部類。這些內部類通常可供同一軟件包內全部類進行訪問,由此可能引發的問題在預定義代碼范圍部分已經提到。因此,同樣請僅在必要時使用內部類。

原則五:確保類不可克隆

Java提供一項功能,用于在需要時對自有類進行克隆。然而這項功能往往被黑客所利用,其能夠使用java.lang.Cloneable從代碼中復制代碼實例并竊取必要信息。

要解決這個問題,大家只需要在代碼中的每個類中添加以下代碼。

public final void clone()throws 
 
java.lang.CloneNotSupportedException { 
 
    thrownewjava.lang.CloneNotSupportedException(); 
 
} 

如果大家希望自己的class具備可克隆性,同時仍然盡可能避免安全問題,那么則可自行定義克隆方法,并將其設置為final。

如果大家在自己的某個超類中使用了nonfinal克隆方法,則請按以下方式定義該方法:

public final void clone() 
 
throwsjava.lang.CloneNotSupportedException { 
 
    super.clone(); } 

當然,沒人能100%掌握Java的全部奧秘,但關注上述編程原則及實踐,能夠幫助大家更為有效地降低代碼內bug數量。

同志們,加油!

 

來自:http://developer.51cto.com/art/201611/521610.htm

 

 本文由用戶 齊萬山 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!