概述
git cherry-pick可以理解为”挑拣”提交,它会获取某一个分支的单笔提交,并作为一个新的提交引入到你当前分支上。 当我们需要在本地合入其他分支的提交时,如果我们不想对整个分支进行合并,而是只想将某一次提交合入到本地当前分支上,那么就要使用git cherry-pick了。
用法
git cherry-pick [<options>] <commit-ish>...
常用options:
--quit 退出当前的chery-pick序列
--continue 继续当前的chery-pick序列
--abort 取消当前的chery-pick序列,恢复当前分支
-n, --no-commit 不自动提交
-e, --edit 编辑提交信息
git cherry-pick commitid
在本地仓库中,有两个分支:branch1和branch2,我们先来查看各个分支的提交:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
现在,我想要将branch2分支上的第一次提交内容合入到branch1分支上,则可以使用git cherry-pick命令:
|
1 2 3 4 5 |
|
当cherry-pick时,没有成功自动提交,这说明存在冲突,因此首先需要解决冲突,解决冲突后需要git commit手动进行提交:
|
1 2 3 4 5 |
|
或者git add .后直接使用git cherry-pick --continue继续。
现在查看提交信息:
|
1 2 3 4 |
|
branch2分支上的第二次提交成功合入到了branch1分支上。
以上就是git cherry-pick的基本用法,如果没有出现冲突,该命令将自动提交。
git cherry-pick -n
如果不想git cherry-pick自动进行提交,则加参数-n即可。比如将branch2分支上的第三次提交内容合入到branch1分支上:
|
1 2 3 4 |
|
本文详细介绍了Gitcherry-pick命令的使用,包括其功能、如何从一个分支选取单个提交合并到另一个分支,以及处理合并冲突的方法。通过实例演示了如何在不自动提交的情况下执行cherry-pick,以及如何在遇到冲突时进行解决。
1648

被折叠的 条评论
为什么被折叠?



