git cherry pick<commit>做什么?


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

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

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


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

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

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

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

不适用:

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

其他链接:

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


此引用摘自:Git版本控制

使用gitcherry-pick命令gitcherri-pick-commit应用命名提交在当前分支上引入的更改。它会引入一个新的、不同的提交。严格来说,使用gitcherry pick不会改变存储库中的现有历史;相反,它增加了历史。与其他Git操作一样通过应用diff的过程引入更改,您可能需要解决冲突以完全应用给定提交中的更改。gitcherry-pick命令通常用于介绍从存储库中的一个分支提交到另一个分支。A.常见的用法是从维护中转发或返回端口提交分支到开发分支。

$ git checkout rel_2.3
$ git cherry-pick dev~2 # commit F, below

之前:

之后:

此外,这里有一个非常棒的视频教程:Youtube:Gitcherry-pick简介


cherry-pick是Git的一个功能。如果有人想在一个分支中向目标分支提交特定的提交,那么使用cherry-pick。吉特樱桃镐步骤如下。

签出(切换到)目标分支。gitcherry-pick<提交id>这里提交id是另一个分支的活动id。吉特樱桃镐9772dd546a3609b06f84b680340fb84c5463264f推到目标分支

参观https://git-scm.com/docs/git-cherry-pick


这有点像复制(从某处)和粘贴(到某处),但用于特定的提交。

例如,如果您想进行热修复,那么可以使用樱桃采摘功能。

在一个开发分支中进行樱桃采摘,并将其合并到一个发布分支中。同样,从一个释放树枝上摘樱桃给主人。沃伊拉


你可以想一想,如果樱桃采摘类似于重基,或者更确切地说,它是像重基一样管理的。我的意思是,它接受一个现有的提交,并以当前所在分支的负责人为起点重新生成它。

rebase接受一个具有父级X的提交,并重新生成该提交,就像它实际上具有父级Y一样,这正是cherry pick所做的。

Cherry pick更关注如何选择提交。使用pull(rebase),git会在拉到分支的内容上隐式地重新生成本地提交,但使用cherry-pick,您会显式地选择一些提交,并在当前分支上隐式重新生成。

因此,您的操作方式有所不同,但本质上它们是非常相似的操作-提交的再生。


当你需要樱桃采摘时,情况的简短示例

考虑以下场景。你有两个分支。a) release1-该分支机构将面向您的客户,但还有一些bug需要修复。b) master-经典主分支,例如可以在其中添加版本2的功能。

现在:你在release1中修复了一些东西。当然,您也需要在master中进行此修复。这是樱桃采摘的典型用例。因此,在这个场景中,cherry-pick意味着您从release1分支获取提交并将其包含到主分支中。


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

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


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

git cherry-pick master~2 master~0

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

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

git cherry-pick master~2

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


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

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


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


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


相同的动画:


注:

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

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


它将对当前分支应用特定的提交。

这意味着:

将添加此提交添加的所有文件将删除此提交删除的所有文件将合并此提交修改的所有文件。这意味着提交后的整个文件,而不仅仅是提交后的更改!

示例:考虑提交A

added newFileA
modified main:
+ import './newFileA'

提交B

added newFileB
modified main:
+ import './newFileB'

如果你在另一个分支上选择commit B,你将得到:

/newFileB
/main :
   import './newFileA'
   import './newFileB'

由于commit B包含newFileB和main,但没有newFileA,因此会导致错误,因此请谨慎使用。


官方文件摘录:

给定一个或多个现有提交,对每个提交应用更改介绍,记录每个人的新提交。这需要您工作树是干净的(没有来自HEAD提交的修改)。当不清楚如何应用更改时,会发生以下情况:当前分支和HEAD指针停留在上次提交时成功制作。CHERRY_PICK_HEAD引用设置为指向引入的提交难以应用的更改。干净应用更改的路径在索引文件和工作树中。对于冲突的路径,索引文件最多记录三个版本,如如gitmerge的“TRUE MERGE”部分所述。工作树文件将包含冲突的描述通常的冲突标记是>>>>>>和>>>>>>>>。未进行其他修改。

阅读更多。。。