不只女人要保養(yǎng),代碼也是如此。面向?qū)ο?a target="_blank">編程,就是把面對(duì)的代碼當(dāng)作對(duì)象一樣,定期對(duì)其進(jìn)行保養(yǎng)。
目錄
一、美顏 Astyle+Source Insight
二、祛痘 cppCheck
三、返老還童 git
四、工欲善其事必先利其器
一、美顏 Astyle+Source Insight
1.1真假小龍女的問(wèn)題
都說(shuō)秀色可餐,同樣的角色,都是小龍女,但是效果不一樣。
實(shí)現(xiàn)同樣的功能,有的代碼一目了然,像詩(shī)一樣賞心悅目;有的卻像SHI一樣,如下面的代碼,雖然功能正常,但看起來(lái)什么感覺(jué)?
正如女人愛(ài)美一樣,出門必化妝,拍照必美顏;代碼也是需要美顏妝扮,除非你期望后來(lái)接手者在心中的十萬(wàn)個(gè)詛咒,這TM誰(shuí)寫的?尤其對(duì)嵌入式系統(tǒng)產(chǎn)品,升級(jí)維護(hù)周期長(zhǎng),軟件的可讀性就顯得更加重要;代碼規(guī)范對(duì)后續(xù)維護(hù)升級(jí)是大有裨益的。
1.2 代碼格式化
一般公司不缺編碼規(guī)范,缺的是執(zhí)行。小項(xiàng)目單人完成,編碼風(fēng)格隨心所欲;大項(xiàng)目團(tuán)隊(duì)完成,編碼風(fēng)格各不相同。目前來(lái)說(shuō),個(gè)人只發(fā)現(xiàn)go語(yǔ)言是編譯時(shí)強(qiáng)制格式化,其他語(yǔ)言編譯時(shí),不檢查排版格式。對(duì)于編碼規(guī)范,不能依靠個(gè)人主觀,強(qiáng)推工具自動(dòng)實(shí)現(xiàn)才能提高執(zhí)行力。
不管編碼使用Keil/MDK、Qt等集成工具,或者純粹的代碼編輯工具Source Insight,一般都支持自定義運(yùn)行可執(zhí)行文件,如Astyle。可以客制化新菜單,一鍵執(zhí)行Astyle,將代碼一鍵格式化,排版統(tǒng)一、層次分明。
Astyle官網(wǎng) http://astyle.sourceforge.net/ 按要求下載安裝,只需要AStyle.exe即可。關(guān)于其使用和參數(shù),可以在進(jìn)入Documentation。對(duì)代碼基本風(fēng)格,{}如何對(duì)齊、是否換行,switch-case如何排版,tab鍵占位寬度,運(yùn)算符或變量前后的空格等等,基本上代碼排版涉及的方方面面都有參數(shù)說(shuō)明。個(gè)人選擇的編碼參數(shù)是
效果如下
建議先參考文檔逐個(gè)熟悉作用,確認(rèn)參數(shù),然后集成到編輯工具,以Source Insight為例。
1、在選項(xiàng)或者工具下(不同Source Insight版本不同)打開(kāi)“自定義命令”,添加命令和運(yùn)行。
2、選擇正確的路徑,結(jié)合前面的參數(shù)類型,最后必須加上%f,表示對(duì)該文件執(zhí)行,
C:AStyle.exe --style=allman -S -U -t -n -K -p -s4 -j -q -Y -xW -xV %f
3、將該命令插入到編輯菜單,后續(xù)在編輯欄點(diǎn)擊Astyle,即可對(duì)當(dāng)前文件自動(dòng)進(jìn)行格式化排版。
1.3 高級(jí)配置
前面只是Source Insight的基礎(chǔ)擴(kuò)展,下面簡(jiǎn)要說(shuō)明下高級(jí)擴(kuò)展宏功能,本文只是描述下基本流程。1、配置菜單
2、插入之后,在主菜單欄會(huì)出現(xiàn)“工作”的菜單,點(diǎn)擊Insertifdef,彈出如下對(duì)話框
3、確定之后自動(dòng)在光標(biāo)處插入代碼
4、不止是支持插入if defined ,還包括插入文件頭,對(duì)h文件插入避免多次包含的宏,對(duì)函數(shù)插入注釋,以及自動(dòng)添加編輯時(shí)間、作者名稱等。這些宏配置和前面一樣,至于客制化,比如函數(shù)注釋的內(nèi)容、格式等,也是可以自由定義。5、配置路徑如下
先關(guān)閉全部Source Insight工程,再打開(kāi)Base.PR,編輯utils.em。如前面的宏 Insertifdef就是如下的代碼
如Ask就是彈出提示語(yǔ),sz獲取輸入的內(nèi)容,再InsBufLine插入兩行代碼。而這些接口的使用說(shuō)明,只要打開(kāi)Source Insight的幫助即可查看。
Ask說(shuō)明:
例如插入函數(shù)注釋的代碼如下:
最終自動(dòng)插入的函數(shù)注釋顯示效果如下:
6、其他宏也是這樣,可以自由配置,當(dāng)然,開(kāi)啟這個(gè)功能的第一步是先編輯,替換全部szMyName為自己的名字。有一點(diǎn)需要注意的是插入函數(shù)注釋時(shí),光標(biāo)必須在該函數(shù)第一個(gè){內(nèi),否則無(wú)法獲取函數(shù)名,會(huì)提示錯(cuò)誤。
1.4 總結(jié)
Source Insight集成Astyle自動(dòng)排版,統(tǒng)一風(fēng)格;集成宏定義,統(tǒng)一注釋格式、提高效率。
二、祛痘 cppCheck
2.1 祛痘除隱患
依靠美顏可以掩蓋面部瑕疵,如痘痘,但為了極致,應(yīng)該從根源祛痘,素顏就美,淡妝濃抹總相宜。代碼規(guī)范整齊,還要沒(méi)有隱患,大部分開(kāi)發(fā)人員都對(duì)警告視而不見(jiàn),覺(jué)得隱患沒(méi)啥大問(wèn)題,
同樣的美女,若是一臉痘痘,顏值瞬間下降。代碼也是如此,編譯警告如同痘痘,看起來(lái)不礙事,實(shí)際對(duì)代碼的質(zhì)量和后期維護(hù)都是隱患,要培養(yǎng)習(xí)慣,凡是警告都要消滅的習(xí)慣。
另外對(duì)于編碼規(guī)范,不只是排版布局,還有命名規(guī)范,例如宏定義使用小寫字母,就必須指出要求修改。所以,代碼必須經(jīng)過(guò)祛痘,除去小隱患,嚴(yán)苛的要求,造就趨于完美的代碼。但是,依靠人工檢查效率低下,靜態(tài)掃描順便檢查命名規(guī)范的神器應(yīng)運(yùn)而生。
代碼的靜態(tài)檢測(cè)工具有很多,為什么推薦cppCheck?因?yàn)樗荙t實(shí)現(xiàn)且開(kāi)源。作為嵌入式軟件開(kāi)發(fā),Qt可以錦上添花,它本身可以多平臺(tái)運(yùn)行,平時(shí)使用它開(kāi)發(fā)小工具,模擬驗(yàn)證部分代碼,比起在真機(jī)編譯下載調(diào)試快捷方便。
cppCheck官網(wǎng)http://cppcheck.net/,可以下載執(zhí)行文件和源碼,稍微有Qt基礎(chǔ)的,可以下載源碼,其Qt工程如下,可以根據(jù)自身要求和能力,進(jìn)行二次開(kāi)發(fā)。
實(shí)現(xiàn)代碼自動(dòng)格式化和靜態(tài)分析,可以有效規(guī)避軟件風(fēng)險(xiǎn)。基于開(kāi)源的Cppcheck,集成Astyle,結(jié)合實(shí)際開(kāi)發(fā)平臺(tái)和編碼標(biāo)準(zhǔn),使用Qt集成的codeCheck誕生了。
codeCheck執(zhí)行的流程,先將C語(yǔ)言代碼自動(dòng)格式化,按指定的規(guī)則排版對(duì)齊,調(diào)整代碼間空格和間距,特殊語(yǔ)句強(qiáng)制換行或添加括號(hào)等,簡(jiǎn)單操作即可完成代碼格式統(tǒng)一化(也就是上一章的配置參數(shù))。然后拆分代碼字符,建立token數(shù)據(jù)庫(kù),按預(yù)置的規(guī)則分析代碼是否存在匹配的非法代碼,并直觀顯示風(fēng)險(xiǎn)代碼位置以便跟蹤修復(fù)。codeCheck不具備編譯語(yǔ)法分析,因此導(dǎo)入的文件必先確保編譯正常,再進(jìn)行分析才有意義。
針對(duì)實(shí)際開(kāi)發(fā)中的問(wèn)題點(diǎn),比如變量命名沖突,或者關(guān)鍵變量缺少注釋導(dǎo)致維護(hù)升級(jí)困難,特別增加了個(gè)性化掃描標(biāo)準(zhǔn)。由于個(gè)人時(shí)間和水平有限,工具還存在優(yōu)化改進(jìn)的必要,但基本可滿足常規(guī)應(yīng)用和新人培養(yǎng)。
即使沒(méi)有Qt基礎(chǔ),直接使用開(kāi)源版本,也是相當(dāng)給力的,二次開(kāi)發(fā)只是錦上添花而已。
2.2 代碼掃描與靜態(tài)分析
個(gè)人二次開(kāi)發(fā)后的主界面如下,和原始的cppcheck差不多,只是多了命名規(guī)范檢查(全局變量必須g_開(kāi)頭,帶注釋;宏定義、枚舉值禁止包含小寫字母等)。
“分析”導(dǎo)入文件或文件夾后,即可啟動(dòng)自動(dòng)格式化并分析代碼邏輯,顯示結(jié)果如下:
選擇“分析結(jié)果”欄,則顯示掃描出的風(fēng)險(xiǎn)代碼,標(biāo)明風(fēng)險(xiǎn)類型和代碼位置,具體顯示如下圖。
2.3 源碼分析
非cppcheck源碼,二次開(kāi)發(fā)的代碼片段。
2.4 總結(jié)
實(shí)現(xiàn)代碼自動(dòng)格式化和靜態(tài)分析,可以有效規(guī)避軟件風(fēng)險(xiǎn)。
三、返老還童 git
3.1 月光寶盒
愛(ài)情不可期,往事成追憶。至尊寶可以使用月光寶盒穿越時(shí)空去尋找愛(ài)情。對(duì)于女人,擁有月光寶盒,即使容顏衰老,也可以回到過(guò)去,返老還童,永葆青春。
對(duì)于程序員,一份完美的代碼,修修補(bǔ)補(bǔ),幾經(jīng)折騰終于封板;因?yàn)楸4娌簧苹蛘咝薷挠涗泚G失,那種痛苦也是一般人無(wú)法想象的。為了不會(huì)有失去才后悔莫急的痛楚,必須使用版本控制來(lái)追溯代碼的過(guò)去,程序員的月光寶盒就是Git神器。
3.2 版本控制git
不必說(shuō)你有多聰明,每天拷貝一份代碼加描述備份;也不要說(shuō)以往的svn等工具有多先進(jìn);這些工具在git的分布式軟件版本控制面前,都不值一提,雖然Git也有缺點(diǎn),但是依然不能掩蓋它的光芒。
十年來(lái),一直是嵌入式軟件開(kāi)發(fā),80%的時(shí)間使用windows版的git可視化操作,相比命令行,更容易掌握與使用,查看版本記錄也更加直觀,命令行的操作方式不在本文考慮范圍。git官網(wǎng)https://git-scm.com/。
1、安裝TortoiseGit-2.5.0.0-64bit.msi 一路下一步,這只是安裝了git的內(nèi)核功能,要在windows下操作,需要安裝界面外殼。
2、安裝GitExtensions-2.50.02-SetupComplete.msi 或者 Git-2.15.0-64-bit.exe,這是兩種風(fēng)格的界面,主體功能差不多,個(gè)人選擇的是后者。也可以兩個(gè)都安裝。
3、安裝過(guò)程中出現(xiàn)較多的配置,所有選項(xiàng)中,全部都選帶windows關(guān)鍵字的,否則用起來(lái)看不出問(wèn)題,但是保存的記錄異常。
既然是界面操作,就開(kāi)啟鼠標(biāo)右鍵的快捷圖標(biāo)。
后續(xù)一些安裝選項(xiàng),全部選帶windows關(guān)鍵字的。
4、安裝完成后,鼠標(biāo)右鍵,會(huì)出現(xiàn) Git GUI Here。
5、如果是新手可安裝漢化補(bǔ)丁TortoiseGit-LanguagePack-2.5.0.0-64bit-zh_CN.msi,建議不要安裝,翻譯有點(diǎn)搞笑(rebase-變基)。
3.3 基礎(chǔ)演示
1、配置
2、創(chuàng)建本地版本庫(kù),git creat repository here,默認(rèn)操作,即可創(chuàng)建版本,會(huì)在test空文件夾下生成.git 。
3、在test下隨便改動(dòng),如新加123.txt,提交改動(dòng)。此時(shí)鼠標(biāo)右鍵
4、保存本次修改后,使用Git GUI Here->Repository->Visualize master's History查看全部版本記錄。
5、通用配置和常用功能
3.4 總結(jié)
Git的使用尤其是多人合作,注意以下幾點(diǎn):
1、推送服務(wù)器前先同步;
2、2個(gè)分支版本有沖突,先rebase解決;熟練操作前不要使用merge;
3、版本節(jié)點(diǎn)不能使用中文,修改描述可以;
4、編譯自動(dòng)生成的不要提交,可以使用TortoiseGit-->Delete and add in ignore list,濾指定的文件,即使有改動(dòng)也不提交;
5、Git自帶的比較工具比較差,可以配置使用外部比較工具。
一共三處,將Diff viewer和Merge Tool改為HA-BCompare。這個(gè)工具的比較功能強(qiáng)大,顯示界面清晰。
四、工欲善其事必先利其器
工欲善其事必先利其器,工具的熟練掌握、合理利用。代碼規(guī)范化,靜態(tài)掃描排除風(fēng)險(xiǎn),修改記錄保存完整,如此,才能保證代碼的質(zhì)量。
責(zé)任編輯:xj
原文標(biāo)題:程序員:女人要保養(yǎng),代碼也是如此~
文章出處:【微信公眾號(hào):玩轉(zhuǎn)單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
-
代碼
+關(guān)注
關(guān)注
30文章
4803瀏覽量
68756 -
程序員
+關(guān)注
關(guān)注
4文章
953瀏覽量
29822
原文標(biāo)題:程序員:女人要保養(yǎng),代碼也是如此~
文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論