赞
踩
概述
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 |
|
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。