要移动检出分支的分支指针,可以使用git reset——hard命令。但是如何移动未签出分支的分支指针指向不同的提交(保持所有其他东西,如跟踪远程分支)?


当前回答

如果你想将一个未检出的分支移动到另一个提交,最简单的方法是运行git branch命令,带-f选项,它决定分支HEAD应该指向的位置:

Git branch -f <branch-name> (<sha1-commit-hash>或<branch-name>)

例如,如果你想让你的本地开发分支跟踪远程(起源)开发分支:

Git branch -f develop origin/develop

要小心,因为如果您试图移动的分支是当前分支,这将不起作用。 使用实例移动分支指针。 git update-ref -m "reset:重置为" refs/heads/ "

git update-ref命令安全地更新保存在ref中的对象名称。

霍普,我的回答帮助了你。信息的来源是这个片段。

其他回答

Git 2.23.0引入了Git -switch命令,该命令也可以用于完成此任务。

git switch -C <branch-name> [<start-point>]

-C(大写C)选项表示如果<branch-name>已经存在,则将其重置为<起始点>。

使用-c(小写C),它将尝试创建一个新的分支,但如果已经存在则会失败。

<start-point>可以是一个散列、一个标记或另一个分支名称。

对于检出的分支,在你想要指向的提交在当前分支之前的情况下(除非你想撤销当前分支的最后一次提交,否则应该是这样),你可以简单地做:

git merge --ff-only <commit>

这是一个较软的git重置的替代方案——很难,如果你不是在上面描述的情况下,就会失败。

对一个未签出的分支做同样的事情,等价的是:

git push . <commit>:<branch>

为了丰富讨论内容,如果你想将myBranch分支移动到当前提交,只需省略-f之后的第二个参数

例子:

吉特妙兰


我通常这样做,当我在一个分离的头部状态下重新设置:)

你可以对任意裁判这样做。这是如何移动分支指针:

git update-ref -m "reset: Reset <branch> to <new commit>" refs/heads/<branch> <commit>

其中-m为分支的reflog添加一条消息。

一般形式是

git update-ref -m "reset: Reset <branch> to <new commit>" <ref> <commit>

如果你喜欢,你可以挑关于reflog消息的虱子-我相信branch -f是不同于reset -难的,这不是他们中的任何一个。

总之:

右键单击要提交的文件 ->创建新分支 输入现有分支的名称 在确认替换该名称的旧分支的对话框上按回车键。

注意,重新创建而不是修改现有的分支将丢失跟踪分支信息。(对于只有一个远程且本地分支与远程中相应分支具有相同名称的简单用例来说,这通常不是问题。查看评论了解更多细节,感谢@mbdevpl指出这个缺点。)

如果gitk有这样一个特性,对话框有3个选项:覆盖、修改现有的或取消,那就太棒了。


即使你通常像我一样是命令行迷,git gui和gitk也为它们所允许的git使用子集而精心设计。我强烈推荐使用他们擅长的(例如,在git gui中有选择地将块放入/取出索引,也只是提交。(按ctrl-s添加一个签名:行,按ctrl-enter提交。)

当您将更改整理成一个漂亮的补丁系列提交给上游时,Gitk非常适合跟踪几个分支,或者其他任何需要跟踪多个分支中间内容的地方。

我甚至没有打开图形文件浏览器,但我喜欢gitk/git gui。