不要毫無計(jì)劃地寫代碼,思考憎亚、調(diào)研员寇、計(jì)劃弄慰、編碼、測試丁恭、修改曹动,一個(gè)都不能少;
不要寫代碼前過度計(jì)劃牲览,在一頭鉆進(jìn)代碼前做點(diǎn)計(jì)劃是好事墓陈,但是即便是好事,也可能物極必反第献。
請勿低估代碼質(zhì)量的重要性贡必,如果你只能夠關(guān)注你所寫的代碼的一個(gè)方面,那么肯定是可讀性庸毫。
使用實(shí)現(xiàn)功能的最簡單方案仔拟,作為專業(yè)的程序員,你的職責(zé)不是找出問題的一個(gè)解決方案飒赃,而是找出問題的最簡單的解決方案利花;
適時(shí)放棄,當(dāng)你開始懷疑一個(gè)解決方案的時(shí)候载佳,你就應(yīng)該考慮拋棄它炒事,并且重新思考這個(gè)問題。不管你已經(jīng)在這個(gè)解決方案中投入了多少精力蔫慧。像 GIT 這樣的版本控制系統(tǒng)能夠幫助你分開管理和嘗試多種不同的解決方案挠乳,把它利用起來吧;
擅用 Google姑躲,除非你正在使用一種極其前沿的技術(shù)睡扬,否則當(dāng)你遇到一個(gè)問題時(shí),很可能別人早就遇到過同樣的問題了黍析,并且也找到了解決方案了卖怜。給自己省點(diǎn)時(shí)間,先 Google 一下阐枣;
做好封裝韧涨,基本的想法就是你想你的代碼高內(nèi)聚和低耦合,意思是說保持相關(guān)的代碼在一起(在一個(gè)類中)侮繁,降低不同類之間的相互依賴虑粥;
做好規(guī)劃,寫好需求再寫代碼宪哩,盡可能編寫目前正在實(shí)現(xiàn)的方案所需的最少量代碼娩贷;
要懂算法,使用合適的數(shù)據(jù)結(jié)構(gòu)锁孟;
不要寫重復(fù)性代碼彬祖,要用好配置文件茁瘦,不要使用沒必要的條件語句和臨時(shí)變量;
做好代碼注釋储笑,但是不要給傻子都知道的代碼寫注釋甜熔;
一定要寫好測試,如果可能的話突倍,甚至在開始寫代碼實(shí)現(xiàn)需求之前腔稀,你就應(yīng)該開始預(yù)估和設(shè)計(jì)需要測試校驗(yàn)的情況了。測試驅(qū)動(dòng)開發(fā) (Testing-driven development, TDD)不是什么花俏的炒作羽历,它是會(huì)實(shí)實(shí)在在會(huì)對你思考功能特性焊虏、尋找更好的設(shè)計(jì)方案產(chǎn)生積極影響的。
不要覺得代碼運(yùn)行起來就是正確的秕磷,有些時(shí)候代碼的 bug 可能并不是顯而易見的诵闭;
要能夠質(zhì)疑既有代碼,作為一個(gè)初學(xué)者澎嚣,總是應(yīng)該假定那些你讀不懂的疏尿、且沒有文檔注釋的代碼很可能就是糟糕的代碼。質(zhì)疑之易桃,詢問之褥琐,使用 git blame 揪出罪魁禍?zhǔn)祝?/p>
不要過度迷戀最佳實(shí)踐,我覺得 "最佳實(shí)踐" 其實(shí)是害人的颈抚,它暗示著你不需要深入研究它,這就是有史以來最佳實(shí)踐嚼鹉,不用質(zhì)疑贩汉!
不要過度迷戀性能優(yōu)化,如果你在運(yùn)行代碼之前就在優(yōu)化它了锚赤,那很可能你就是在過早優(yōu)化代碼了匹舞,也很可能你正在費(fèi)時(shí)費(fèi)力做的優(yōu)化是完全沒必要的。
以用戶體驗(yàn)為目標(biāo)线脚,要站在最終用戶的角度看問題赐稽。專業(yè)的開發(fā)者要考慮這個(gè)特定功能的用戶需要什么、怎樣使用浑侥,要想方設(shè)法使得這個(gè)功能容易讓用戶發(fā)現(xiàn)和使用姊舵,而不是想方設(shè)法在應(yīng)用中用最便捷添加這個(gè)功能,毫不考慮這個(gè)功能的可發(fā)現(xiàn)性和可用性寓落。
為你的開發(fā)任務(wù)挑選合適的工具括丁,你可以使用最原始的工具建造房子,然后享受甜蜜時(shí)光伶选。你也可以花費(fèi)一些時(shí)間和金錢去了解先進(jìn)的工具史飞、更快地建造更好的房子尖昏。工具在不斷地改進(jìn)中,你要樂意去學(xué)習(xí)它們构资、使用它們抽诉。
要理解好代碼問題和數(shù)據(jù)問題之間的關(guān)系,即使是程序中最小的 bug 也會(huì)導(dǎo)致它所管理的數(shù)據(jù)去到一種不可預(yù)測的狀態(tài)吐绵。尤其是當(dāng)所有數(shù)據(jù)校驗(yàn)都完全在這個(gè)有 bug 的程序中進(jìn)行時(shí)迹淌。
切勿重復(fù)造輪子,使用好現(xiàn)有的輪子和各種開源庫拦赠,會(huì)讓你事半功倍巍沙。當(dāng)然,不要僅僅為了使用一兩個(gè)函數(shù)就引入一整個(gè)代碼庫荷鼠,在 JavaScript 中的典型例子就是 lodash 代碼庫句携;
對代碼審查保持正確的態(tài)度,應(yīng)該把每一次代碼復(fù)審當(dāng)作是學(xué)習(xí)的機(jī)會(huì)允乐,歡迎他們矮嫉、感激他們、從中學(xué)習(xí)牍疏,最重要的蠢笋,當(dāng)你從你的代碼復(fù)審人員那里學(xué)習(xí)到東西的時(shí)候,要感謝他們鳞陨;
用好版本控制工具和系統(tǒng)昨寞,新手往往低估了一個(gè)好的版本控制系統(tǒng)的威力,我這里所說的好的版本控制系統(tǒng)其實(shí)就是指 Git厦滤;
不要過度使用共享狀態(tài)援岩,一個(gè)新手可能會(huì)嘗試使用定時(shí)器來解決這個(gè)共享變量的競態(tài)條件問題,特別是當(dāng)他們必須處理一個(gè)數(shù)據(jù)鎖的問題時(shí)掏导。這是危險(xiǎn)的標(biāo)志享怀,別這么做,注意它趟咆,在代碼復(fù)審中指出它添瓷,永遠(yuǎn)也不要接受這樣的代碼。
正視 Error值纱,Error 是好東西鳞贷。Error 意味著你在進(jìn)步,意味著你可以通過簡單的后續(xù)修改就獲得更多的進(jìn)步虐唠。專業(yè)程序員喜愛 Error悄晃。新手則痛恨 Error;
學(xué)會(huì)休息,任何人的大腦都需要休息妈橄,身體也需要休息庶近。
我忘記是哪位大佬寫的,感覺有意思眷蚓,也感覺寫的有道理鼻种,保存下來了。哈哈