閱讀源碼怎么高效學(xué)?
現(xiàn)在很多剛工作的開(kāi)發(fā)想要進(jìn)階,能想到的途徑就是閱讀別人的項(xiàng)目源碼,尤其是好的開(kāi)源中的技術(shù)棧。很多人選擇買一本《xx源碼解析》類的書(shū),直接開(kāi)始看書(shū),剛開(kāi)始的看的時(shí)候非常吃力,跟不上,而且會(huì)覺(jué)得書(shū)非常無(wú)聊。
閱讀源碼的好處
讀源碼的目的是讓我們學(xué)習(xí)大佬的想法和技巧,通過(guò)大量的閱讀進(jìn)行積累,將有用的代碼放在自己的常用代碼中,把一些零碎的知識(shí)點(diǎn)結(jié)合起來(lái)。其次就是讓我們積累經(jīng)驗(yàn),因?yàn)楹芏嚅_(kāi)源組件會(huì)出現(xiàn)各種各樣的問(wèn)題,我們沒(méi)遇到但是可以參考前輩的經(jīng)驗(yàn)。閱讀源碼更好的理解項(xiàng)目,另外就是在工作的時(shí)候我們會(huì)翻遍了各種開(kāi)源的庫(kù),也沒(méi)有合適的組件供我們直接使用,那需要開(kāi)發(fā)者對(duì)現(xiàn)有的組件進(jìn)行改造的時(shí)候,改造條件就是深入理解代碼。
閱讀源碼的實(shí)例
在某技術(shù)論壇上看到了一個(gè)人,從來(lái)沒(méi)有一次完整的閱讀過(guò)源碼,但是非常想嘗試。于是說(shuō)干就干,在GitHub上給自己制定了一個(gè)計(jì)劃,預(yù)計(jì)15天完成源碼的閱讀,并且每天記錄下收貨:
閱讀源代碼是軟件開(kāi)發(fā)中非常重要的技能之一。理解代碼背后的邏輯和結(jié)構(gòu)有助于提高編程能力、解決問(wèn)題以及學(xué)習(xí)新的編程語(yǔ)言和框架。以下是一些閱讀源代碼的原因以及一些建議:
為什么要讀源代碼:
學(xué)習(xí)新技術(shù)和框架: 閱讀源代碼是學(xué)習(xí)新技術(shù)和框架的有效途徑。通過(guò)直接查看源代碼,你可以深入了解其實(shí)現(xiàn)方式、設(shè)計(jì)思想和最佳實(shí)踐。
解決問(wèn)題: 當(dāng)你在使用某個(gè)庫(kù)或框架時(shí)遇到問(wèn)題,查看其源代碼可以幫助你更好地理解問(wèn)題的根本原因,并找到解決方案。
提高編程技能: 閱讀高質(zhì)量的源代碼可以提高你的編程技能,幫助你更好地理解算法、數(shù)據(jù)結(jié)構(gòu)和設(shè)計(jì)模式。
了解最佳實(shí)踐: 通過(guò)閱讀開(kāi)源項(xiàng)目的源代碼,你可以學(xué)到一些編碼和設(shè)計(jì)的最佳實(shí)踐,有助于提高代碼質(zhì)量。
參與開(kāi)源社區(qū): 閱讀和理解開(kāi)源項(xiàng)目的代碼是參與開(kāi)源社區(qū)的第一步。這有助于你理解項(xiàng)目的內(nèi)部工作方式,為項(xiàng)目做出貢獻(xiàn)。
如何閱讀源代碼:
了解項(xiàng)目結(jié)構(gòu): 在開(kāi)始閱讀源代碼之前,先了解項(xiàng)目的整體結(jié)構(gòu)和組織。查看項(xiàng)目的文檔、README 文件以及主要的目錄結(jié)構(gòu)。
選擇關(guān)鍵部分: 不必閱讀整個(gè)代碼庫(kù),選擇項(xiàng)目的關(guān)鍵部分進(jìn)行深入閱讀。這可以包括主要算法、核心功能或與你的興趣相關(guān)的部分。
注重關(guān)鍵文件和函數(shù): 閱讀重要的文件和函數(shù),這有助于你理解代碼的核心邏輯。關(guān)注那些命名有意義、注釋清晰的部分。
使用調(diào)試器: 在閱讀代碼的過(guò)程中,使用調(diào)試器來(lái)單步執(zhí)行代碼,觀察變量的值和程序流程。這有助于更好地理解代碼的執(zhí)行過(guò)程。
查找依賴關(guān)系: 理解代碼之間的依賴關(guān)系和調(diào)用關(guān)系是很重要的。查看函數(shù)和模塊之間的關(guān)系,了解它們是如何協(xié)同工作的。
參考文檔和注釋: 閱讀文檔和源代碼中的注釋,這些信息對(duì)于理解代碼的設(shè)計(jì)思想、用法和約定非常有幫助。
與社區(qū)互動(dòng): 如果你在閱讀開(kāi)源項(xiàng)目的過(guò)程中遇到問(wèn)題,可以與項(xiàng)目的社區(qū)互動(dòng),提出問(wèn)題或參與討論。這有助于更深入地理解代碼。
源碼閱讀干貨
(1)主要用途
首先我們要知道這個(gè)項(xiàng)目的目標(biāo)是什么,為了什么才寫出來(lái)的。不要第一步都沒(méi)搞清楚,看了一個(gè)與你目前工作毫無(wú)瓜葛的源碼。比如logback 而言,它的用途就是打日志。而它所有的代碼無(wú)論多復(fù)雜,終極目標(biāo)就是要讓 logback 能健壯高效的打印出日志來(lái)。
(2)項(xiàng)目架構(gòu)
還是以logback為例,源碼提供了架構(gòu)圖,就直接從中了解整體架構(gòu),如果沒(méi)有,可以看看討論組有沒(méi)有大神提供,如果還沒(méi)有,哪就只能自己畫(huà)出來(lái)。
只有自己清楚架構(gòu)的價(jià)值在哪,才能清楚的了解系統(tǒng)的層次結(jié)構(gòu),理出項(xiàng)目核心脈絡(luò)。
(3)運(yùn)行項(xiàng)目
搞清楚了整體脈絡(luò)還需要我們嘗試把項(xiàng)目運(yùn)行起來(lái)。
如果在運(yùn)營(yíng)過(guò)程中遇到問(wèn)題,自己需要通過(guò)調(diào)試去解開(kāi)問(wèn)題,比如方法變量不知其意,邏輯跳轉(zhuǎn)問(wèn)題,還有封裝對(duì)象層次太深。以上情況,都需要自行調(diào)節(jié)代碼。
更多內(nèi)容《百人技術(shù)團(tuán)隊(duì)總監(jiān):開(kāi)源項(xiàng)目學(xué)習(xí)的秘訣》
總結(jié)
我們需要對(duì)全局有一個(gè),有架構(gòu)圖的就了解架構(gòu)圖沒(méi)有的就自己畫(huà)一個(gè)。其次是自己讓項(xiàng)目運(yùn)行起來(lái),最后捋清楚業(yè)務(wù),最后是攻克問(wèn)題。想要開(kāi)始閱讀,但不知道從何而起的同學(xué)們,可以給自己列一個(gè)計(jì)劃。閱讀源代碼需要時(shí)間和耐心,但這是一個(gè)非常有價(jià)值的學(xué)習(xí)過(guò)程。逐漸地,你會(huì)發(fā)現(xiàn)自己能夠更快地理解和編寫高質(zhì)量的代碼。