git cherry pick<commit>做什么?
当前回答
它将对当前分支应用特定的提交。
这意味着:
将添加此提交添加的所有文件将删除此提交删除的所有文件将合并此提交修改的所有文件。这意味着提交后的整个文件,而不仅仅是提交后的更改!
示例:考虑提交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”部分所述。工作树文件将包含冲突的描述通常的冲突标记是>>>>>>和>>>>>>>>。未进行其他修改。
阅读更多。。。
cherry-pick是Git的一个功能。如果有人想在一个分支中向目标分支提交特定的提交,那么使用cherry-pick。吉特樱桃镐步骤如下。
签出(切换到)目标分支。gitcherry-pick<提交id>这里提交id是另一个分支的活动id。吉特樱桃镐9772dd546a3609b06f84b680340fb84c5463264f推到目标分支
参观https://git-scm.com/docs/git-cherry-pick
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樱桃采摘指南
你可以想一想,如果樱桃采摘类似于重基,或者更确切地说,它是像重基一样管理的。我的意思是,它接受一个现有的提交,并以当前所在分支的负责人为起点重新生成它。
rebase接受一个具有父级X的提交,并重新生成该提交,就像它实际上具有父级Y一样,这正是cherry pick所做的。
Cherry pick更关注如何选择提交。使用pull(rebase),git会在拉到分支的内容上隐式地重新生成本地提交,但使用cherry-pick,您会显式地选择一些提交,并在当前分支上隐式重新生成。
因此,您的操作方式有所不同,但本质上它们是非常相似的操作-提交的再生。
推荐文章
- 如何从远程Git存储库中提取并覆盖本地存储库中的更改?
- Github:导入上游分支到fork
- Git单次修订的日志
- Git在不改变提交时间戳的情况下进行改基
- VS 2017 Git本地提交数据库。每次提交时锁定错误
- 如何在过去的一些任意提交之间注入一个提交?
- 从GitHub克隆项目后拉git子模块
- GitHub上的分叉和克隆有什么区别?
- 递归地按模式添加文件
- 我如何使用notepad++(或其他)与msysgit?
- 如何将现有的解决方案从Visual Studio 2013添加到GitHub
- Git存储库中的悬垂提交和blob是什么?它们来自哪里?
- 我如何简单地从我最新的git提交创建一个补丁?
- Git显示“警告:永久添加到已知主机列表”
- 我如何检索一个回购的远程git地址?