Github上fork的项目怎么更新同步原项目

Github上fork的项目怎么更新同步原项目

在GitHub上我们会去fork别人的一个项目,然后在自己的GitHub中会生成一个副本,自己将副本clone到电脑本地上可以修改代码,修改之后push提交到远端remote中的origin,发现自己的GIthub副本中的代码改变了,而作者变更的代码没有同步下来,这时你需要合并原作者的最新代码过来, 让你的项目变成最新的。

一般有两种做法,第一种做法可谓简单粗暴,但却不是最好的做法,说明如下:

  • 第一种:将自己仓库中原来fork的项目删掉 (delete deletethis repository),然后在重新到原作者仓库中(fork)一份最新代码(不推荐方式),这似乎达到了我们的最终目的,但是自己改变的代码没合并进来。
  • 第二种:在本地建立两个库的中介,把两个远程库都clone到本地,然后拉取原项目更新到本地,合并更新,最后push到你的github就完成。(推荐方式)

具体实现:

(1)准备一个本地目录,并克隆自己fork的项目到本地。

$ git clone https://github.com/jp1017/FastAndroid.git

(2)然后cd 进入仓库(这里我直接进入项目根目录下),执行命令:

$ git remote -v

可以在cad控制台查看本地项目目录,如下:

图1.png

(3)我们可以看到,只有我们自己的远程仓库,下面clone原项目到该仓库

$ git remote add hunter https://github.com/huntermr/FastAndroid.git
$ git remote -v

hunter 相当于一个别名,名字随便取。


图2.png

(4)这时有两个远程分支,我们继续 fetch,然后把原项目更新的内容fetch到本地

$ git fetch hunter

(5)查看下分支:

$ git branch -av
图3.png

(6)一个本地分支master,三个远程分支,画红线的就是要合并的 merge

$ git checkout master
$ git merge hunter/master
图4.png

(7)如果有冲突的话,需要丢掉本地分支:

$ git reset –hard hunter/master 

(8)这时你的当前本地的项目变成和原作者的主项目一样了,可以把它提交到你的GitHub库

$ git commit -am ‘更新到原作者的主分支’
$ git push origin 
$ git push -u origin master -f –强制提交
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值