git cherry pick<commit>做什么?
当前回答
当你需要樱桃采摘时,情况的简短示例
考虑以下场景。你有两个分支。a) release1-该分支机构将面向您的客户,但还有一些bug需要修复。b) master-经典主分支,例如可以在其中添加版本2的功能。
现在:你在release1中修复了一些东西。当然,您也需要在master中进行此修复。这是樱桃采摘的典型用例。因此,在这个场景中,cherry-pick意味着您从release1分支获取提交并将其包含到主分支中。
其他回答
此引用摘自: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简介
如果要在没有提交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的指针)。
cherry-pick是Git的一个功能。如果有人想在一个分支中向目标分支提交特定的提交,那么使用cherry-pick。吉特樱桃镐步骤如下。
签出(切换到)目标分支。gitcherry-pick<提交id>这里提交id是另一个分支的活动id。吉特樱桃镐9772dd546a3609b06f84b680340fb84c5463264f推到目标分支
参观https://git-scm.com/docs/git-cherry-pick
当你需要樱桃采摘时,情况的简短示例
考虑以下场景。你有两个分支。a) release1-该分支机构将面向您的客户,但还有一些bug需要修复。b) master-经典主分支,例如可以在其中添加版本2的功能。
现在:你在release1中修复了一些东西。当然,您也需要在master中进行此修复。这是樱桃采摘的典型用例。因此,在这个场景中,cherry-pick意味着您从release1分支获取提交并将其包含到主分支中。
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别