零维护

 找回密码
 立即注册
快捷导航
搜索
热搜: 活动 交友 discuz
查看: 105|回复: 2

如何高效学习 GitHub 项目源代码

[复制链接]

1

主题

3

帖子

5

积分

新手上路

Rank: 1

积分
5
发表于 2022-11-29 13:36:42 | 显示全部楼层 |阅读模式
​先分享个段子。
问:你为什么还没有女朋友
笑死,我在 GitHub 根本不需要女朋友!
1、

之前,小帅b给你分享了一个 GitHub 插件:Sourcegraph,可以使用它在浏览器中直接查看 GitHub 中的源代码:



现在不需要安装插件那么麻烦,你只需要在仓库地址中,在 github 后面加个 1s,就可以直接查看源码了:



这是个人开发者做的,不久前官方也做了个类似的,你可以在仓库地址中的 「com」改为 「dev」,也可以看到类似的效果:



更舒服的操作是,你直接在 Github 项目仓库页面中,在键盘按一下「.」,它会自动把项目重定向 github.dev 去,直接用 vs code 的方式查看源码,一步到位:



2、

通过在线查看 GitHub 源码的方式比较适合参考代码风格、具体方法的逻辑实现,但如果是要学习 GitHub 中的某个项目,最好还是要 clone 到本地,然后在本地上把项目运行起来,完完全全使用一波,在这个过程中你会找到自己的疑问。
有些项目需要搭建好环境,安装各种依赖的框架才能跑得起来,仅凭这一点就阻碍了不少人进入下一步学习。clone 的时候动力满满,项目跑不起来直接劝退自己,然后玩游戏看视频去了。
我想他们并不是真的想学,或者说不是他们真的刚需,所以动力不足。想想你刚入职一家新的公司时,你需要在短时间内熟悉了解工作的项目,如果项目复杂一些,你会慌的一批,但你一定会想方设法,各种搜寻,把环境搭建来,让项目运行起来,然后熟悉各种流程。
所以你想学习一个新的项目的时候,不妨把它想得「严重」一点,想想学会后自己的价值有所提升的成就感。
3、

当你把功能都操作一遍之后,你会找到侧重点,比如有些功能是你觉得非常简单的,那么这部分你可以不用太关心,但你一定会发现有些是你不会的,有些是你会的但是你想知道它是如何实现的。
反正,跑起来并操作所有功能之后,你会得到:
1,疑问?(不知道功能如何实现)
2,好奇!(知道如何实现但想知道作者和自己的不同之处)
有了好奇和疑问,这满满的「刚需」,这动力会驱使你想要去学习其中的代码。
4、

一行一行代码仔细看嘛?
也许可以,但我觉得先大致看一下项目代码结构,然后使用 debug 的方式更有效,python 有 pdb,各种编辑器也有 debug 工具,比如 Pychram:



因为你已经有自己的侧重点,在你有疑问或者想知道如何实现的地方,打一个「断点」,然后一边运行一遍看结果,你会非常清晰其中的逻辑。



小帅b和他的朋友们推荐搜索
github
4.1

举一个简单的例子,比如我看到了一个 2048 小游戏的项目:



我想知道,当我按下方向键之后,数字叠加是如何实现的,新的随机数是如何产生的?那么就可以在「点击事件」下打一个断点:



这时候你通过 debug 的方式把项目运行起来:



然后按一下方向键就会定位到当前执行到断点处的代码。



接着就可以使用「step into」或者「setp over」执行接下来的每一步操作。



需要看函数具体调用就可以 step into,需要直接看执行后的下一行就可以 step over。
4.2

这样可以在你想关注的地方,知道代码的每一步都做了什么,比如这里的 2048,就是通过二维数组实现的:



通过一步一步执行,很快你会发现,每次都会不断随机一个空位,然后赋值一个 2:



如何实现数字叠加更新的呢?一样,在关键处打个断点,你会发现主要实现逻辑在这里:



每个方法你都可以 step into 进去,最后你会发现,这里的实现是重新排序数组,然后判断相邻的非空数据是否相等,有就进行 「*=2」:



我演示的这个项目地址:https://github.com/yangshun/2048-python
这样,通过你的每一步执行,你能很清晰地看到作者是如何思考的,你也从中得到了解惑。
如何搜到适合你的项目?看我之前写的:几个 GitHub 高级搜索技巧,这就分享给你。
5、

当然,你在 debug 的过程中,肯定没我刚刚演示的那样顺利,你会遇到一些问题,比如:
有些逻辑实现看不懂
有些算法看不懂
甚至有些语法都看不懂
....
别叹气,这时候你应该感到开心,因为这正是你的「学习机会」,你只是暂时还不知道它们,而现在,你已经「知道自己不知道什么东西」了,所以耐下心来,一直重复 debug 很多遍那些「自己不会的关键地方」,每一步都要去想。
实在想不出来?可以去项目的 Issues 中翻一翻,再者,可以使用搜索引擎搜索的嘛,倘若很久还是搞不懂(概率很小),那就直接找到作者,给他发个大红包,虚心请教人家。
帅言帅语:方法总比困难多!
直到某个时刻,你一定学会了「自己不知道的东西」,接下来还没完,可以在原有的项目框架中,按照你刚学会的「新知」,添加一个相关的功能,自己独立去实现它,相信这时候对你来说简单许多。
为什么要多做这一步,因为这是「根本」,我们是为了使用,而不是仅仅为了「懂」。
通过这样进一步的的行动,其实是一次很好的总结。也许在这过程你会发现你并没有真正的理解呢。(别问我怎么知道的,哭)
反正如此这般折腾一番之后,你会发现意外的惊喜,比如:
发现了比自己更好的实现方式
发现了自己从来没使用过的库
发现了新的特性
发现自己变得更帅了(这点我深有体会)
....
更爽的是,折腾完之后,让子弹飞一会,因为它会在你的脑子里生成新的「节点」,它很大概率在你未来的某个业务会被关联到,直接用得上!
6、

OK,以上就是小帅b给你分享的一点经验,当然,我知道大部分人看了也不会行动,毕竟很多人关注了我公众号然后就让它躺在列表中,也有的是点进来之后,随便划一下就退出,然后还总是抱怨:要是我xxx也不至于xxx。
我更希望以上的内容能给你带来一点参考,你可以慢慢地去执行,然后在过程中找到适合自己的「方法论」,去体验其中的乐趣,扎实的成长。
像你这种认真看完了,三连了,还去默默执行的,咋能一样呢?
我们下回见,peace!
最后:

欢迎加入小帅b的 VIP,陪你一起学习 Python:通往 Python 高手之路
回复

使用道具 举报

0

主题

1

帖子

0

积分

新手上路

Rank: 1

积分
0
发表于 2022-11-29 13:37:02 | 显示全部楼层
推荐个人GitHub账号 有多个个人开源项目 标星2.8k 主要关注计算机视觉和后端开发 http://github.com/Charmve 欢迎来我主页 相信你一定有收获
回复

使用道具 举报

1

主题

3

帖子

7

积分

新手上路

Rank: 1

积分
7
发表于 4 天前 | 显示全部楼层
支持,赞一个
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver| 手机版| 小黑屋| 零维护

GMT+8, 2025-4-7 23:48 , Processed in 0.088725 second(s), 20 queries .

Powered by Discuz! X3.4

Copyright © 2020, LianLian.

快速回复 返回顶部 返回列表