今天給大家聊聊編程培訓(xùn)之編碼規(guī)范,為了提高工作效率,保證開(kāi)發(fā)的有效性和合理性,并最大程度提高程序代碼的可讀性和重復(fù)利用性,提高溝通效率,需要一份代碼編寫(xiě)規(guī)范。
一、代碼規(guī)范的重要性
①促進(jìn)團(tuán)隊(duì)合作。
項(xiàng)目是由一個(gè)團(tuán)隊(duì)來(lái)完成,如果沒(méi)有統(tǒng)一的代碼規(guī)范,那么每個(gè)人的代碼必定風(fēng)格迥異。多個(gè)人同時(shí)開(kāi)發(fā)同一模塊,等到要整合代碼的時(shí)候也很頭疼,可讀性差。
②減少Bug處理。
減少低級(jí)錯(cuò)誤發(fā)生。再?gòu)?fù)雜的邏輯看起來(lái)也是很清晰。規(guī)則不統(tǒng)一,容易出錯(cuò)。步調(diào)一致,減少細(xì)節(jié)思考。
③降低維護(hù)成本。
方便后面的人進(jìn)行代碼閱讀和維護(hù),減少程序耦合性,方便在之前的模塊上擴(kuò)展一些功能??删S護(hù)性高。
④有助代碼審查。
代碼審查有據(jù)可依。減少代碼審查的工作量。統(tǒng)一度量標(biāo)準(zhǔn)。
⑤有助自身成長(zhǎng)。
誰(shuí)能保證之后不需要來(lái)維護(hù)自己的代碼。在緊張的項(xiàng)目進(jìn)度要求下,提高自身工作效率,產(chǎn)生高質(zhì)量代碼。防止后續(xù)別人讀自己的代碼,心里默默在罵你。一定要高效率,專業(yè)。
二、代碼規(guī)范的要求
良好的工程結(jié)構(gòu)
目錄結(jié)構(gòu)要清晰,例如很多框架采用了mvc設(shè)計(jì)思想。模型放一個(gè)目錄,視圖放一個(gè)目錄,控制器放一個(gè)目錄。大家可以下載相關(guān)的mvc設(shè)計(jì)思想的框架,例如:ThinkPHP、Laravel。
使用DRY原則
不要重復(fù)你的代碼。拆分可重用函數(shù)或類,使用常量定義。
使用有意義并一致命名
不要使用拼音命名,不要沒(méi)有明確含義的命名。
變量命名:變量的名詞性(形容詞+名詞),長(zhǎng)名字可用下劃線連接。
函數(shù)名:小駝峰式(如:getUserInfo())。函數(shù)的動(dòng)詞性(動(dòng)詞+形容詞+名詞;謂語(yǔ)+賓語(yǔ))
類的命名:大駝峰式(如:UserInfo)類的名詞性:如:OrderModel。不可出現(xiàn)下劃線。
適當(dāng)留空和必要縮進(jìn)
使用tab鍵縮進(jìn)(不可使用4個(gè)空格來(lái)代替縮進(jìn))。
留空(使用空格、換行、空行)
避免深嵌套
嵌套不應(yīng)該大于3層。函數(shù)不應(yīng)該有多個(gè)出口。
添加應(yīng)有的注釋
注釋塊
文件頭:名詞,版權(quán),作者。
類:類作用解釋。
函數(shù):函數(shù)作用,入?yún)?shù),返回內(nèi)容。
注釋行 //:幫助記憶
代碼說(shuō)明:一般用于對(duì)某個(gè)邏輯塊的說(shuō)明。
結(jié)束提示:常用于if、switch、while邏輯體結(jié)束說(shuō)明。
待開(kāi)發(fā)提示
調(diào)試提示
變量聲明和初始化
避免聲明的局部變量覆蓋上一級(jí)聲明的變量
使用前必須將變量初始化
變量名盡量體現(xiàn)數(shù)據(jù)類型
永遠(yuǎn)不要相信用戶
天真的用戶:只要有輸入框,就會(huì)出現(xiàn)各種輸入內(nèi)容
不懷好意者:會(huì)想辦法通過(guò)輸入注入惡意內(nèi)容
防范措施:前端對(duì)輸入進(jìn)行校驗(yàn)。后端對(duì)于輸入校驗(yàn)必不可少,不能假設(shè)前端做了正確的校驗(yàn)。存在你也不知道的入口。攻擊者會(huì)直接通過(guò)編造請(qǐng)求的方式進(jìn)行提交。防止各種注入。
合理使用緩存機(jī)制
建議使用緩存機(jī)制緩存獲得更好的性能。例如:redis、memcached等。
避免代碼的Copy和
沒(méi)有理解代碼的含義,就呆板的拷貝復(fù)制??截悂?lái)的代碼未必就是對(duì)的。如果有重復(fù)代碼,意味著可以拆分出一個(gè)功能函數(shù)。
盡量多使用框架
框架的目的是為了提高開(kāi)發(fā)效率。框架是前輩們知識(shí)和經(jīng)驗(yàn)積累而來(lái),是被證明了的成熟解決方案。絕大數(shù)框架基于MVC(模型視圖控制器)架構(gòu)理念而開(kāi)發(fā)。選擇適合自己的框架。好了到這就是編程培訓(xùn)之編碼規(guī)范篇的全部?jī)?nèi)容,