简介
含义: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 编辑提交信息
使用示例
在本地仓库中,有两个分支branch1和branch2
# 切换到branch2分支
$ git checkout branch2
Switched to branch 'branch2'
# 查看branch2最近三次提交
$ git log --oneline -3
23d9422 [Description]:branch2 commit 3
2555c6e [Description]:branch2 commit 2
b82ba0f [Description]:branch2 commit 1
# 切换到branch1分支
$ git checkout branch1
Switched to branch 'branch1'
# 要将branch2分支上的第一次提交内容合入到branch1分支
$ git cherry-pick commit 1
当cherry-pick时,没有成功自动提交,这说明存在冲突,因此首先需要解决冲突,解决冲突后需要git commit手动进行提交;
或者git add .后直接使用git cherry-pick --continue继续。