推荐一篇良许大佬的文章, 如何在 github 上大显身手。拥有自己的 github, 且有所贡献, 这是一件很有意义的的事情, 在面试上也是加分项哦,赶紧搞起来。转载至 http://uee.me/aHAfN 这推荐一个网站,收集了有趣、入门级的开源项目:https://hellogithub.com/
码农朋友们都知道,gitHub 是一个面向开源及私有软件项目的托管平台,上面托管了众多的优秀的项目,比如 linux 内核源码、git 源码、机器学习框架 tensorflow 等等。当然,除了这些顶尖项目外,还有海量的高手开发的优秀项目。所有的这些项目,我们都可以为它贡献代码。
那么,要如何为这些项目贡献代码呢?我们下面以实例来讲解。
比如说,现在 gitHub 上有个很牛逼的项目 githubTest,它的作者是 Alvin,项目地址如下:
https://github.com/yychuyu/githubTest
现在 Harry 看到了这个项目,想要对它进行贡献代码。想要达到这个目的,Harry 要完成下图的这些步骤:
1. fork
Harry 在找到这个项目之后,点击右上角的「fork」按钮。稍等片刻后,就会在 Harry 的账号下克隆了一个一样的项目 githubTest,包括文件,提交历史,issues,和其余一些东西。
2. clone
通过 fork 之后,Harry 的账号下也有了 githubTest 这个项目,但还不能对它进行编译、修改(其实是可以修改,但是不建议)。
这时,可以通过 git clone 命令,将这个项目 clone 到自己的电脑里。
3. update a file & 4. commit
接下来,Harry 就可以大显身手了,可以自由对这个项目进行修改。但是,不建议在 master 分支直接修改,建议在 master 分支基础上切出一个 dev 分支,然后在 dev 分支上自由发挥。修改完之后,再将 dev 分支 merge 到 master 分支。
5. push
在自己的电脑上修改好代码之后,再使用 git push 命令将改动同步到自己的 gitHub 项目仓库里。
通过这个操作后,就可以在代码仓库里看到自己的提交了。
6. pull request
接下来,就是向原作者 Alvin 提交你的代码了。首先点击文件列表上的「New pull request」。
之后,gitHub 会自动对源仓库分支及自己仓库分支代码进行比对,看看是否有冲突。如果它显示「Able to merge」的话,Harry 就可以点击下面的「Create pull request」绿色按钮,进行代码提交。
再之后,系统会要求你写一段注释,其实也可不写。但最好写一下,跟作者说明一下你改动了什么,为啥这么改。
通过以上 6 步,原作者 Alvin 就会收到一个 pull request,如下图:
然后,Alvin 可以点进去,看看 Harry 具体提交了一些什么修改。如果他觉得这个修改确实够 niubility 的话,它就可以点击「merge pull request」,将 Harry 的提交集成到自己的项目里。
[图片上传中 …(image-19e584-1547014948798-10)]
至此,功德圆满,Harry 顺利完成一次对项目 githubTest 的代码贡献。
但是,这个项目实在太出众了,很多高手看到了并贡献了众多代码。比如现在 Alvin 自己提交了一个文件:
现在原作者项目已经发生了改变,那 Harry 账号下的 githubTest 如何与原作者 Alvin 的项目保持同步呢?Harry 需要做以下三步操作:
1. fetch
现在代码不同步了,我们要先把 Alvin 仓库的代码 fetch 到自己电脑的仓库下。注意,这是在自己电脑上操作,不是在 github 上操作。
git fetch git@github.com:yychuyu/githubTest.git master:latest
上面这条命令,git fetch 之后 的那部分,是原作者 Alvin 项目 git 地址,通过点击原项目「clone or download」按钮可以看到。再之后 master:latest 这部分,master 是原项目分支,latest 是自己项目分支。如果 latest 分支不存在的话,将自动创建。其实也可以将代码 fetch 到自己的 master 分支,但也不建议这么做。
2. merge
代码 fetch 到 latest 分支之后,再切到 master 分支,再使用 git merge 命令将最新代码合并到 master 分支。
3. push
现在,Harry 电脑上的代码与原项目代码保持同步了。我们再使用 git push 命令,就可以将最新代码推到 Harry 账号下 githubTest 项目里
以上的三个步骤具体操作过程如下图示。
接下来,Harry 就可以在此基础上,继续贡献自己的代码了。
推荐阅读:
IDEA 热部署插件 JRebel
「神器」强大的系统清理工具
THANDKS
End –
一个立志成大腿而每天努力奋斗的年轻人
伴学习伴成长,成长之路你并不孤单!