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