git cherry pick<commit>做什么?


当前回答

我准备了一步一步的插图,樱桃树做什么,以及这些插图的动画(接近尾声)。

樱桃采摘前(我们将从分支特性中选择提交L):


启动命令git cherry pick功能~2(功能~2是之前的第二次提交特征,即提交L):


执行命令后(git cherry-pick feature~2):


相同的动画:


注:

提交L’从用户的角度来看(提交=快照)是提交L的精确副本。

从技术上讲(内部),它是一个新的、不同的提交(因为例如,L包含指向K的指针(作为其父级),而L'包含指向e的指针)。

其他回答

Git中的Cherry picking旨在将一些提交从一个分支应用到另一个分支。如果您犯了一个错误,并将更改提交到错误的分支,但不想合并整个分支,则可以这样做。你可以恢复提交,然后在另一个分支上重新选择。

要使用它,您只需要gitcherry-pick-hash,其中hash是来自其他分支的提交哈希。

有关完整程序,请参阅:http://technosophos.com/2009/12/04/git-cherry-picking-move-small-code-patches-across-branches.html

当您与一个项目开发团队合作时,管理多个git分支之间的更改可能会成为一项复杂的任务。有时您不想将整个分支合并到另一个分支中,只需要选择一个或两个特定的提交。这个过程叫做“樱桃采摘”。

找到了一篇很棒的关于樱桃采摘的文章,请查看详细信息:https://www.previousnext.com.au/blog/intro-cherry-picking-git

我准备了一步一步的插图,樱桃树做什么,以及这些插图的动画(接近尾声)。

樱桃采摘前(我们将从分支特性中选择提交L):


启动命令git cherry pick功能~2(功能~2是之前的第二次提交特征,即提交L):


执行命令后(git cherry-pick feature~2):


相同的动画:


注:

提交L’从用户的角度来看(提交=快照)是提交L的精确副本。

从技术上讲(内部),它是一个新的、不同的提交(因为例如,L包含指向K的指针(作为其父级),而L'包含指向e的指针)。

Git中的樱桃采摘意味着从一个分支中选择一个提交并将其应用到另一个分支。

这与其他方法(如合并和重基)形成对比,后者通常将许多提交应用到另一个分支。

也可以选择多次提交,但合并是首选的选择方式。

确保您位于要应用提交的分支上。git开关主机执行以下操作:gitcherry-pick<提交哈希>

不适用:

如果你从公共部门挑选,你应该考虑使用gitcherry-pick-x<提交哈希>这将生成标准化的提交消息。这样,您(和您的同事)仍然可以跟踪提交的来源,并可能避免将来的合并冲突。如果您在提交时附加了注释,则它们不会遵循樱桃树。为了让他们也过来,你必须使用:gitnotes复制<from><to>

其他链接:

git官方指南页面git樱桃采摘指南

如果要在没有提交ID的情况下进行合并,可以使用以下命令

git cherry-pick master~2 master~0

上面的命令将主服务器的最后三次提交从1合并到3

如果要对单个提交执行此操作,只需删除最后一个选项

git cherry-pick master~2

这样,您将合并从master结尾的第三个提交。