不管用的是哪種編程語言,在編寫代碼時(shí),bug永遠(yuǎn)是困擾每一位程序員的頭號(hào)難題。java開發(fā)程序員也不例外,為了能夠減少bug的存在,在編程中就需要非常注意。Java開發(fā)減少bug存在有哪些小技巧?老師提出了這幾點(diǎn)。
1、不要依賴初始化老師表示,在Java中,開發(fā)者常常依賴構(gòu)造函數(shù)進(jìn)行對(duì)象初始化。不過這其實(shí)是一種常見誤區(qū)。我們完全可以在無需調(diào)用構(gòu)造函數(shù)的情況下,通過多種方式實(shí)現(xiàn)對(duì)象分配。
下面來看幾種常用方式:可以將所有變量聲明為私有。要訪問該類外的對(duì)象,也可使用GET與SET方法。對(duì)每個(gè)對(duì)象,編寫一個(gè)新的私有Boolean變量并對(duì)其進(jìn)行初始化。編寫一個(gè)非構(gòu)造函數(shù)類,其將確保每個(gè)對(duì)象會(huì)在接受調(diào)用之前進(jìn)行初始化。
2、保護(hù)類、方法與變量
Java程序員在代碼當(dāng)中,要將類、方法與變量分為私有與公共兩類。私有類無法輕松進(jìn)行訪問,這使其成為代碼中的高安全性點(diǎn)。不過公共方法與變量則易于方法,也因此常常成為攻擊突破口。因此,請(qǐng)盡可能限制其范圍。請(qǐng)記住,只在必要時(shí)開放類、方法與變量。
3、避免使用內(nèi)部類
一般來講,開發(fā)者會(huì)在同一軟件包內(nèi)其它類需要時(shí)使用內(nèi)部類。這些內(nèi)部類通常可供同一軟件包內(nèi)全部類進(jìn)行訪問,由此可能引發(fā)的問題在預(yù)定義代碼范圍部分已經(jīng)提到。因此建議程序員在必要時(shí)使用內(nèi)部類。
4、永遠(yuǎn)對(duì)范圍進(jìn)行預(yù)定義
大多數(shù)開發(fā)者完全依賴于軟件包自身的范圍設(shè)定,事實(shí)上我們應(yīng)當(dāng)堅(jiān)持對(duì)代碼范圍進(jìn)行預(yù)定義。很多類本身并非完全封閉,這意味著攻擊者能夠?qū)ζ涫┮怨?。黑客可以利用單一漏洞插入自己的類,進(jìn)而從代碼中提取敏感信息。JVM在默認(rèn)情況下即不會(huì)封閉,不過允許大家在該軟件包內(nèi)進(jìn)行類封閉。
5、確保類不可克隆
Java編程提供一項(xiàng)功能,用于在需要時(shí)對(duì)自有類進(jìn)行克隆。然而這項(xiàng)功能往往被黑客所利用,其能夠使用Java.lang.Cloneable從代碼中復(fù)制代碼實(shí)例并竊取必要信息。要解決這個(gè)問題,大家只需要在代碼中的每個(gè)類中添加適當(dāng)代碼即可。如果大家希望自己的class具備可克隆性,同時(shí)仍然盡可能避免安全問題,那么則可自行定義克隆方法,并將其設(shè)置為final。
當(dāng)然,沒人能完全掌握J(rèn)ava的全部奧秘,但遵循上述編程原則及實(shí)踐,老師希望能夠幫助大家更為有效地降低代碼內(nèi)bug數(shù)量。
想了解更多相關(guān)資訊請(qǐng)關(guān)注java培訓(xùn)頻道-查看更多,了解相關(guān)專業(yè)課程信息您可在線咨詢也可免費(fèi)申請(qǐng)?jiān)囌n。關(guān)注賦能網(wǎng)了解更多:4008-569-579
本文鏈接:
本文章“學(xué)習(xí)Java開發(fā)預(yù)防bug有哪些技巧”已幫助 100 人
免責(zé)聲明:本信息由用戶發(fā)布,本站不承擔(dān)本信息引起的任何交易及知識(shí)產(chǎn)權(quán)侵權(quán)的法律責(zé)任!
本文由賦能網(wǎng) 整理發(fā)布。了解更多培訓(xùn)機(jī)構(gòu)》培訓(xùn)課程》學(xué)習(xí)資訊》課程優(yōu)惠》課程開班》學(xué)校地址等機(jī)構(gòu)信息,可以留下您的聯(lián)系方式,讓課程老師跟你詳細(xì)解答:
咨詢熱線:4008-569-579