結(jié)論
成都創(chuàng)新互聯(lián)公司是專業(yè)的甕安網(wǎng)站建設(shè)公司,甕安接單;提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行甕安網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
我覺(jué)得學(xué)編程,寫(xiě)項(xiàng)目沒(méi)有必要去背代碼,除非你是為了面試,那就可以稍微背一下。你可以先了解網(wǎng)絡(luò)編程相關(guān)的函數(shù)大概了解它們的作用,然后去一些代碼開(kāi)源網(wǎng)站找一些java網(wǎng)絡(luò)編程相關(guān)的項(xiàng)目,然后你嘗試去模仿它,這樣的話,你的編程能力可能就會(huì)進(jìn)步得快一點(diǎn)。
具體操作
在以下網(wǎng)站中進(jìn)行相關(guān)網(wǎng)絡(luò)編程函數(shù)的查詢學(xué)習(xí)。
里面也有相關(guān)例子的講解。
1. 打好基礎(chǔ)
寫(xiě)出高質(zhì)量代碼,并不是搭建空中樓閣,需要有一定的基礎(chǔ),這里我重點(diǎn)強(qiáng)調(diào)與代碼質(zhì)量密切相關(guān)的幾點(diǎn):
掌握好開(kāi)發(fā)語(yǔ)言,比如做Android就必須對(duì)Java足夠熟悉,《Effective Java》一書(shū)就是教授大家如何更好得掌握J(rèn)ava, 寫(xiě)出高質(zhì)量Java代碼。
熟悉開(kāi)發(fā)平臺(tái), 不同的開(kāi)發(fā)平臺(tái),有不同的API, 有不同的工作原理,同樣是Java代碼,在PC上寫(xiě)與Android上寫(xiě)很多地方不一樣,要去熟悉Android編程的一些特性,iOS編程的一些特性,了解清楚這些,才能寫(xiě)出更加地道的代碼,充分發(fā)揮各自平臺(tái)的優(yōu)勢(shì)。
基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)與算法,掌握好這些在解決一些特定問(wèn)題時(shí),可以以更加優(yōu)雅有效的方式處理。
基礎(chǔ)的設(shè)計(jì)原則,無(wú)需完全掌握23種經(jīng)典設(shè)計(jì)模式,只需要了解一些常用的設(shè)計(jì)原則即可,甚至你也可以只了解什么是低耦合,并在你的代碼中堅(jiān)持實(shí)踐,也能寫(xiě)出很不錯(cuò)的代碼。
2. 代碼標(biāo)準(zhǔn)
代碼標(biāo)準(zhǔn)在團(tuán)隊(duì)合作中尤為重要,誰(shuí)也不希望一個(gè)項(xiàng)目中代碼風(fēng)格各異,看得讓人糟心,即便是個(gè)人開(kāi)發(fā)者,現(xiàn)在也需要跟各種開(kāi)源項(xiàng)目打交道。標(biāo)準(zhǔn)怎么定是一個(gè)老生常談的話題,我個(gè)人職業(yè)生涯中經(jīng)歷過(guò)很多次的代碼標(biāo)準(zhǔn)討論會(huì)議,C++, C#, Java等等,大家有時(shí)會(huì)堅(jiān)持自己的習(xí)慣不肯退讓。可現(xiàn)如今時(shí)代不一樣了,Google等大廠已經(jīng)為我們制定好了各種標(biāo)準(zhǔn),不用爭(zhēng)了,就用這些業(yè)界標(biāo)準(zhǔn)吧。
3. 想好再寫(xiě)
除非你很清楚你要怎么做,否則我不建議邊做邊想。
你真的搞清楚你要解決的問(wèn)題是什么了嗎?你的方案是否能有效?有沒(méi)有更優(yōu)雅簡(jiǎn)單的方案?準(zhǔn)備怎么設(shè)計(jì)它,必要的情況下,需要有設(shè)計(jì)文檔,復(fù)雜一些的設(shè)計(jì)需要有同行評(píng)審,寫(xiě)代碼其實(shí)是很簡(jiǎn)單的事情,前提是你得先想清楚。
4. 代碼重構(gòu)
重構(gòu)對(duì)于代碼質(zhì)量的重要性不言而喻,反正我是很難一次把代碼寫(xiě)得讓自己滿意、無(wú)可挑剔,《重構(gòu)》這本書(shū)作為業(yè)內(nèi)經(jīng)典也理應(yīng)人人必讀,也有其他類似的教授重構(gòu)技巧的書(shū),有些也非常不錯(cuò),遺憾的是我發(fā)現(xiàn)很多工作多年的同學(xué)甚至都沒(méi)有了解過(guò)重構(gòu)的概念。
5. 技術(shù)債務(wù)
知乎上最近有個(gè)熱門(mén)問(wèn)題《為什么有些大公司技術(shù)弱爆了?》,其實(shí)里面提到的很多歸根結(jié)底都是技術(shù)債務(wù)問(wèn)題,這在一些大公司尤為常見(jiàn)。技術(shù)債務(wù)話題太大,但就代碼質(zhì)量而言,我只想提一下不要因?yàn)檫@些債是前人留下的你就不去管,現(xiàn)實(shí)是沒(méi)有多少機(jī)會(huì)讓你從一個(gè)清爽清新的項(xiàng)目開(kāi)始做起,你不得不去面對(duì)這些,你也沒(méi)法完全不跟這些所謂的爛代碼打交道。
因此我建議各位:當(dāng)你負(fù)責(zé)一個(gè)小模塊時(shí),除了把它做好之外,也要順便將與之糾纏在一起的技術(shù)債務(wù)還掉,因?yàn)檫@些債務(wù)最終將是整個(gè)團(tuán)隊(duì)來(lái)共同承擔(dān),任何一個(gè)人都別想獨(dú)善其身,如果你還對(duì)高質(zhì)量代碼有追求的話。
作為團(tuán)隊(duì)的技術(shù)負(fù)責(zé)人,也要頂住壓力,鼓勵(lì)大家勇于做出嘗試,引導(dǎo)大家不斷改進(jìn)代碼質(zhì)量,不要總是畏手畏腳,停滯不前,真要背鍋也得上,要有擔(dān)當(dāng)。
6. 代碼審查
我曾經(jīng)聽(tīng)過(guò)一些較高級(jí)別的技術(shù)分享,竟然還不時(shí)聽(tīng)到一些呼吁大家要做代碼審查的主題,我以為在這個(gè)級(jí)別的技術(shù)會(huì)議上,不應(yīng)再討論代碼審查有什么好,為什么要做代碼審查之類的問(wèn)題。同時(shí)我接觸過(guò)相當(dāng)多所謂國(guó)內(nèi)一線互聯(lián)網(wǎng)公司,竟有許多是不做代碼審查的,這一度讓我頗為意外。
這里也不想多談如何做好代碼審查,只是就代碼質(zhì)量這點(diǎn),不客氣地說(shuō):沒(méi)有過(guò)代碼審查經(jīng)歷的同學(xué),往往很難寫(xiě)出高質(zhì)量的代碼,尤其是在各種追求速度的糙快猛創(chuàng)業(yè)公司。
7. 靜態(tài)檢查
很多代碼上的問(wèn)題,都可以通過(guò)一些工具來(lái)找到,某些場(chǎng)景下,它比人要靠譜得多,至少不會(huì)出現(xiàn)某些細(xì)節(jié)上的遺漏,同時(shí)也能有效幫助大家減少代碼審查的工作量。
Android開(kāi)發(fā)中有Lint, Find bugs, PMD等優(yōu)秀靜態(tài)檢查工具可用,通過(guò)改進(jìn)這些工具找出的問(wèn)題,就能對(duì)語(yǔ)法的細(xì)節(jié),規(guī)范,編程的技巧有更多直觀了解。
建議最好與持續(xù)集成(CI),代碼審查環(huán)境配套使用, 每次提交的代碼都能自動(dòng)驗(yàn)證是否通過(guò)了工具的代碼檢查,通過(guò)才允許提交。
8. 單元測(cè)試
Android單元測(cè)試,一直備受爭(zhēng)議,主要還是原生的測(cè)試框架不夠方便,每跑一次用例需要在模擬器或者真機(jī)上運(yùn)行,效率太低,也不方便在CI環(huán)境下自動(dòng)構(gòu)建單元測(cè)試,好在有Robolectric,能幫我們解決部分問(wèn)題。
單元測(cè)試的一個(gè)非常顯著的優(yōu)點(diǎn)是,當(dāng)你需要修改大量代碼時(shí),盡管放心修改,只需要保證單元測(cè)試用例通過(guò)即可,無(wú)需瞻前顧后。
9. 充分自測(cè)
有一種說(shuō)法:程序員最害怕的是他自己寫(xiě)的代碼,尤其是準(zhǔn)備在眾人面前show自己的工作成果時(shí),因此在寫(xiě)完代碼后,需要至少跑一遍基本的場(chǎng)景,一些簡(jiǎn)單的異常流。在把你的工作成果提交給測(cè)試或用戶前,充分自測(cè)是基本的職業(yè)素養(yǎng),不要總想著讓測(cè)試幫你找問(wèn)題,隨便用幾下就Crash的東西,你好意思拿給別人嗎?
10. 善用開(kāi)源
并非開(kāi)源的東西,質(zhì)量就高,但至少關(guān)注度較高,使用人數(shù)較多,口碑較好的開(kāi)源項(xiàng)目,質(zhì)量是有一定保證的,這其中的道理很簡(jiǎn)單。即便存在一些問(wèn)題,也可以通過(guò)提交反饋,不斷改進(jìn)。最重要的是,你自己花時(shí)間造的輪子,需要很多精力維護(hù),而充分利用開(kāi)源項(xiàng)目,能幫助你節(jié)省很多時(shí)間,把精力專注在最需要你關(guān)心的問(wèn)題上。
在我們進(jìn)行編程時(shí),有兩樣?xùn)|西是非常重要的,一是思路,二是語(yǔ)法結(jié)構(gòu)。有了思路,但對(duì)Java這門(mén)語(yǔ)言的語(yǔ)法結(jié)構(gòu)不是特別了解,那么代碼肯定是編寫(xiě)不出來(lái)。
或者說(shuō)對(duì)于Java語(yǔ)言語(yǔ)法結(jié)構(gòu)掌握的還算可以,但是解題卻沒(méi)有思路,代碼肯定是無(wú)從下手的,這也是許多程序員常見(jiàn)的情況。
給你分享三個(gè)方法:
1、拆分法:將功能項(xiàng)目拆解成N個(gè)子功能,保證每個(gè)子功能只需要處理一個(gè)邏輯業(yè)務(wù),返回一個(gè)邏輯結(jié)構(gòu)數(shù)據(jù),跟畫(huà)家畫(huà)一只兔子一樣。很多功能實(shí)現(xiàn)過(guò)于復(fù)雜,需要牽扯到很多方面的問(wèn)題,這時(shí)你只有好好拆分,把大功能靠自己的經(jīng)驗(yàn)拆成多個(gè)獨(dú)立的子功能,這樣每個(gè)子功能的邏輯就不那么復(fù)雜了,自己也可以專心于業(yè)務(wù)邏輯實(shí)現(xiàn)。
2、預(yù)先定義法:很多功能你不知道怎么實(shí)現(xiàn),但是你知道最終返回的數(shù)據(jù)結(jié)構(gòu)應(yīng)該是什么樣子的,那你就預(yù)先把他定義出來(lái),然后提前返回,中間業(yè)務(wù)邏輯部分都是為了填充這個(gè)預(yù)先返回的數(shù)據(jù)結(jié)構(gòu)定義的。其實(shí)程序中充滿著這樣的技巧,各種代碼都是預(yù)先定義好類型、數(shù)據(jù)結(jié)構(gòu)、對(duì)象等等,然后慢慢通過(guò)業(yè)務(wù)邏輯取到值進(jìn)行填充。
3、假設(shè)法:很多時(shí)候程序員需要完成對(duì)接或者功能還未實(shí)現(xiàn),可以采用假設(shè)法,你可以預(yù)先定義好假設(shè)的數(shù)據(jù),假設(shè)的數(shù)據(jù)跟需要的數(shù)據(jù)完全吻合,甚至你可以這樣操作if (true) {},這樣把if里的內(nèi)容全部書(shū)寫(xiě)完畢,然后再來(lái)處理這個(gè)true的問(wèn)題,如果這個(gè)true的時(shí)機(jī)還不成熟,那說(shuō)明不是你的問(wèn)題了,而是別人的問(wèn)題,別人應(yīng)該背鍋,你的績(jī)效就達(dá)成了。