本節(jié)主要是分享光城的實(shí)習(xí)期間如何快速閱讀一些源代碼,以及快速閱讀一些開源庫。
在我自己的開發(fā)過程中,主要圍繞以下三點(diǎn)展開:
-
項(xiàng)目的業(yè)務(wù)/開源項(xiàng)目主要做什么 -
目標(biāo)的建立 -
系統(tǒng)的學(xué)習(xí)
不管是實(shí)習(xí)期間的代碼還是開源項(xiàng)目,例如;STL這種代碼,一般代碼量不少,如何快速的抓住重點(diǎn)變得非常重要,本文接下來圍繞上述三點(diǎn)展開。
1.做什么
首先你得明確自己拿到該開源項(xiàng)目,主要目的是做什么,一般無非兩點(diǎn):
-
速成般的使用 -
科研般的研究
如果重點(diǎn)是放在第一點(diǎn),那么重點(diǎn)是使用,我們不需要它的實(shí)現(xiàn)細(xì)節(jié),只需要把握一些關(guān)鍵的點(diǎn),例如:像TinyXml、RapidJson這種開源項(xiàng)目,快速上手及使用還是比較簡單,而源代碼也是非常的少,這里有個(gè)建議:使用自己比較擅長的IDE來看源代碼,這樣后續(xù)會方便很多,無論是打斷點(diǎn),還是函數(shù)之間的跳轉(zhuǎn),算是效率的提升吧。
針對使用的基礎(chǔ)之上,例如:我想研究priority_queue在STL庫中的實(shí)現(xiàn),怎么快速抓住重點(diǎn)進(jìn)行研究呢?
基于測試般的學(xué)習(xí),如下五點(diǎn):0.下載源代碼,導(dǎo)入IDE 1.編寫測試用例,主調(diào)自己想考慮的函數(shù) 2.梳理類與類之間的繼承關(guān)系 3.剖析自己代碼的版本,例如:C++11特性這些語法的總結(jié) 4.一些奇奇怪怪的點(diǎn),但是又不影響主邏輯
這里還是以實(shí)際例子說明,在STL中很多人對大根堆與小根堆如何構(gòu)建非常迷茫,在我看來,無非重點(diǎn)是比較的意義。下面解釋為啥說了比較的意義這個(gè)重點(diǎn)。
在priority_queue以及map等代碼內(nèi)容的一些實(shí)現(xiàn)中,非常重要的一點(diǎn)是Cmp,也就是比較器,或者說兩個(gè)對象比較的實(shí)現(xiàn)手段,而決定大根堆與小根堆的設(shè)計(jì)原則在于是大于號代表大根堆,還是重載小于號決定小根堆。使用默認(rèn)的greater代表大根堆,還是使用less代表大根堆,這些都是疑問,帶著這些疑問及測試用例調(diào)用函數(shù)邏輯來一步步的解答疑惑。
在基于IDE的基礎(chǔ),我們可以在調(diào)用函數(shù)之處,打上斷點(diǎn),一步步的運(yùn)行,看看堆棧信息,有利于我們理解程序的運(yùn)行軌跡。
在像C++源代碼中,大部分是以類來封裝,我們就需要熟悉類的特性,以及繼承、多態(tài)等的基礎(chǔ)知識,所以說讀源代碼對于學(xué)習(xí)一門語言來說是非常有幫助的,你可以review別人的代碼同時(shí),記錄下;類與類之間的繼承關(guān)系,梳理調(diào)用關(guān)系!
在最新的代碼當(dāng)中,部分及全部支持C++11以上的特性的代碼,需要懂一些新特性的語法知識,對于不懂之處,記錄一些關(guān)鍵字及代碼行數(shù),文件行數(shù),邊review,邊檢索相關(guān)知識,填補(bǔ)漏洞。
最后,便是一些比較奇怪的點(diǎn),在像STL這種源代碼中,會有一些奇能淫巧,不要方,先記錄下來,直接搜就完事了,一般是可以找到解答的,推薦stackflow上搜。例如:EBO,namespace之間的識別順序等等,看似奇怪的代碼,實(shí)際上內(nèi)含很多知識點(diǎn)。
當(dāng)然,上面只提到了開源項(xiàng)目的解決方案,針對業(yè)務(wù)代碼,關(guān)鍵點(diǎn)在于快速的抓住要改動的代碼位置以及代碼邏輯,而一般自己交接的代碼是在某個(gè)特定的框架內(nèi)部進(jìn)行改動業(yè)務(wù)邏輯,這便會非常簡單只需要從下面幾點(diǎn)來:
-
框架主邏輯 -
業(yè)務(wù)的關(guān)鍵字段 -
業(yè)務(wù)函數(shù)入口
快速打破僵局的點(diǎn)在于熟悉框架,入口在哪里,隨后根據(jù)產(chǎn)品的需求來定位關(guān)鍵字段,全局的有策略的檢測,如果還是不懂,就請教負(fù)責(zé)該項(xiàng)目的人,來咨詢相關(guān)的業(yè)務(wù)邏輯,非常復(fù)雜的先把業(yè)務(wù)函數(shù)與框架區(qū)分開,從框架邏輯走位到業(yè)務(wù)函數(shù)即可。
2.目標(biāo)的建立
明確了所做的事,需要給自己設(shè)定一個(gè)開發(fā)的目標(biāo)或者說讀完源碼后的目標(biāo),進(jìn)而促進(jìn)自己不斷的深入下去,學(xué)習(xí)更多的技術(shù)點(diǎn)。
例如:STL當(dāng)中的萃取機(jī)是一個(gè)技術(shù)點(diǎn),在各個(gè)數(shù)據(jù)結(jié)構(gòu)當(dāng)中又是怎么使用的,各個(gè)對外的一些函數(shù)接口的底層實(shí)現(xiàn)邏輯是什么。
在1中實(shí)際上明確了要做什么,此時(shí)是不方的,至少不會被源碼勸退!明確自己當(dāng)前的目標(biāo),一點(diǎn)點(diǎn)來就行了。
3.系統(tǒng)的學(xué)習(xí)
最后便是,系統(tǒng)的梳理一遍之前學(xué)習(xí)的點(diǎn),將其串起來,例如:TinyXMl這種庫代碼非常少,從局部以點(diǎn)帶面的形式擴(kuò)散開來,到最后實(shí)際上看的東西不多了,在下次碰到源碼的時(shí)候不會那么捉急,實(shí)際上這也是經(jīng)驗(yàn)的積累過程,一開始從小的代碼庫,再到大的代碼庫。
4.開源項(xiàng)目的推薦
TinyXml、RapidJson、libco、STL等這些源碼,如果你是C++愛好者可以深入研究一番,還是有點(diǎn)技術(shù)含量的,如果你有這專業(yè)的領(lǐng)域,例如:做圖像,那么看opencv這種,可以研究一番,專業(yè)領(lǐng)域?qū)I(yè)的事,從源代碼看起,大家加油~
本節(jié)完
往期推薦
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!