代碼是否具有可讀性應(yīng)該主要取決于寫的人規(guī)劃的代碼有沒有可讀性,和編程語言本身沒有關(guān)系
成都創(chuàng)新互聯(lián)主營紅塔網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,重慶App定制開發(fā),紅塔h5微信小程序開發(fā)搭建,紅塔網(wǎng)站營銷推廣歡迎紅塔等地區(qū)企業(yè)咨詢
如果現(xiàn)在要求對(duì)你寫的Java代碼進(jìn)行優(yōu)化,那你會(huì)怎么做呢?作者在本文介紹了可以提高系統(tǒng)性能以及代碼可讀性的四種方法,如果你對(duì)此感興趣,就讓java課程一起來看看吧。
我們平時(shí)的編程任務(wù)不外乎就是將相同的技術(shù)套件應(yīng)用到不同的項(xiàng)目中去,對(duì)于大多數(shù)情況來說,這些技術(shù)都是可以滿足目標(biāo)的。
然而,有的項(xiàng)目可能需要用到一些特別的技術(shù),因此工程師們得深入研究,去尋找那些最簡單但最有效的方法。
在以前一篇文章中,我們討論了必要時(shí)可以使用的四種特殊技術(shù),這些特殊技術(shù)可以創(chuàng)建更好的Java軟件;而本文我們將介紹一些有助于解決常見問題的通用設(shè)計(jì)策略和目標(biāo)實(shí)現(xiàn)技術(shù),即:?1.只做有目的性的優(yōu)化?2.常量盡量使用枚舉?3.重新定義類里面的equals()方法?4.盡量多使用多態(tài)性值得注意的是,本文中描述的技術(shù)并不是適用于所有情況。
另外這些技術(shù)應(yīng)該什么時(shí)候使用以及在什么地方使用,都是需要使用者經(jīng)過深思熟慮的。
1.只做有目的性的優(yōu)化大型軟件系統(tǒng)肯定非常關(guān)注性能問題。
雖然我們希望能夠?qū)懗鲎罡咝У拇a,但很多時(shí)候,如果想對(duì)代碼進(jìn)行優(yōu)化,我們卻無從下手。
最重要的是天下沒有免費(fèi)的午餐,因此為了降低代價(jià),我們通常會(huì)通過類似于緩存、循環(huán)展開或預(yù)計(jì)算值這類技術(shù)去實(shí)現(xiàn)優(yōu)化,這樣反而增加了系統(tǒng)的復(fù)雜性,也降低了代碼的可讀性。
如果這種優(yōu)化可以提高系統(tǒng)的性能,那么即使變得復(fù)雜,那也是值得的,但是做決定之前,必須首先知道這兩條信息:?1.性能要求是什么?2.性能瓶頸在哪里首先我們需要清楚地知道性能要求是什么。
如果最終是在要求以內(nèi),并且最終用戶也沒有提出什么異議,那么就沒有必要進(jìn)行性能優(yōu)化。
但是,當(dāng)添加了新功能或者系統(tǒng)的數(shù)據(jù)量達(dá)到一定規(guī)模以后就必須進(jìn)行優(yōu)化了,否則可能會(huì)出現(xiàn)問題。
在這種情況下,不應(yīng)該靠直覺,也不應(yīng)該依靠檢查。
因?yàn)榧词故窍馦artinFowler這樣有經(jīng)驗(yàn)的開發(fā)人員也容易做一些錯(cuò)誤的優(yōu)化,正如在重構(gòu)(第70頁)一文中解釋的那樣:如果分析了足夠多的程序以后,你會(huì)發(fā)現(xiàn)關(guān)于性能的有趣之處在于,大部分時(shí)間都浪費(fèi)在了系統(tǒng)中的一小部分代碼中里面。
如果對(duì)所有代碼進(jìn)行了同樣的優(yōu)化,那么最終結(jié)果就是浪費(fèi)了90%的優(yōu)化,因?yàn)閮?yōu)化過以后的代碼運(yùn)行得頻率并不多。
因?yàn)闆]有目標(biāo)而做的優(yōu)化所耗費(fèi)的時(shí)間,都是在浪費(fèi)時(shí)間。
jsp文件中存在一些java代碼是在所難免的,不然也不用使用jsp了,純html就好了嘛,但對(duì)于題目中的“一部分”是指多少并未可知,如果太多確實(shí)會(huì)有影響的,所以一般不建議這樣做,影響大致如下所列:
1、根據(jù)MVC思想,JSP屬于VIEW層,不宜存在太多java的代碼,view層應(yīng)該只有布局、樣式相關(guān)的代碼,jsp中包含太多java代碼就和MVC思想有出入了。
2、可讀性差,大多公司中,JSP是有專業(yè)的前臺(tái)人員進(jìn)行維護(hù)的,但這些前臺(tái)人員,只需要具備HTML、JS、CSS、JQUERY等前端技術(shù),一般都不懂得Java代碼,在jsp中寫太多java代碼,會(huì)使可讀性變差,不便于前臺(tái)人員維護(hù)。
3、不便于維護(hù)。把多數(shù)java代碼寫在jsp頁面中,而更多的代碼還是在后臺(tái)的java文件中的,這樣在開發(fā)過程中就需要多個(gè)文件一起看,出了問題也要一起修改,這要造成了維護(hù)代碼的負(fù)擔(dān)。
4、不易于調(diào)試。其實(shí)更確切的說是不能調(diào)試。jsp文件中是無法加斷點(diǎn)的,這樣寫出的代碼如果存在問題卻編譯通過的話,想找起來會(huì)相當(dāng)麻煩。
也正因?yàn)闀?huì)有上述所說的這些影響,但開發(fā)者又有時(shí)需要在jsp中輸入java代碼,所以才有jstl、el表達(dá)式等技術(shù)出現(xiàn)可以在jsp頁面替換掉那些復(fù)雜的java代碼。