当前位置:  开发笔记 > 编程语言 > 正文

Git:丢弃分散的本地分支上的所有更改

如何解决《Git:丢弃分散的本地分支上的所有更改》经验,为你挑选了2个好方法。

我有一个跟踪远程分支的本地主题分支.为了论证,请说提交历史如下:

A--B--C--O1--O2--O3 (origin/phobos)
       \
         L1--L2--L3 (phobos)

看了相关的提交历史后,我现在想要丢弃对本地phobos分支的所有更改并将其恢复为直接副本origin/phobos,以便本地历史记录如下所示:

A--B--C--O1--O2--O3 (phobos origin/phobos)

我真的不希望对phobos分支进行本地更改,并且我真的不希望之后在源存储库中显示任何合并.(所以,合并并不是我想到的.)

这看起来应该很容易,但是我的google-fu让我失望了.我该怎么做呢?



1> Dan Moulding..:
git checkout phobos
git reset --hard origin/phobos

这告诉Git将头部重置为与之phobos相同的提交origin/phobos,并更新工作树以匹配.


国际海事组织这应该是公认的答案; 它发出"reset"命令来移植分支指针,而不是通过删除/重新创建进行手术.
@Electrons_Ahoy:嗯,这绝对不正常.如果您的仓库处于良好的工作状态,执行此重置通常应该是无故障运行.

2> mipadi..:

删除分支,然后重新创建它:

$ git branch -D phobos
$ git checkout --track -b phobos origin/phobos


这种方法与重置分支头部的问题在于删除分支会破坏分支的reflog.另一方面,重置分支不仅保留了reflog,而且实际上将重置记录在reflog中.如果需要,这使得操作在以后容易可逆.
@Electrons_Ahoy会建议你将接受的答案改为Dan's(以便像我这样的人用谷歌搜索如何做到这一点可能会选择更安全的方法).
Dan Molding的答案更安全.我认为你应该选择那个.
@ DanMoulding的答案不涉及在不需要时删除本地分支.它更安全.
推荐阅读
跟我搞对象吧
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有