git 的cherry-pick选择性提交

git cherry-pick 是 Git 中的一个非常有用的命令,它允许你将一个或多个特定的提交(commit)从一个分支应用到另一个分支上,而不是合并整个分支。

单个提交的 cherry-pick

假设你有一个 feature 分支,其中有一个提交(Hash值) abc123,你想要将这个提交应用到 master 分支上。你可以按照以下步骤操作:

  • 切换到目标分支

    git checkout master

  • 执行 cherry-pick

    git cherry-pick abc123

这条命令会在 master 分支上创建一个新的提交,这个新提交包含与 abc123 相同的更改,但会有一个不同的提交哈希值。

多个提交的 cherry-pick

如果你想要 cherry-pick 多个连续的提交,可以使用下面的语法:

git cherry-pick <HashA>^..<HashB>

注意,这里的 <HashA>^ 表示从 <HashA> 的父提交开始(即不包括 <HashA> 本身),到 <HashB>(包括 <HashB>)之间的所有提交。但是,更常见的做法是直接列出你想要 cherry-pick 的提交哈希值,用空格分隔:

git cherry-pick <HashA> <HashB> <HashC>

这将在当前分支上依次创建 <HashA><HashB><HashC> 的新提交。

处理合并提交

如果你尝试 cherry-pick 一个合并提交(在 git log 中显示为包含多个父提交的提交),Git 会报错,因为它不知道应该采用哪个父分支的更改。为了解决这个问题,你可以使用 -m 选项来指定合并提交中的一个父分支:

git cherry-pick -m 1 <commitHash>

这里的 -m 1 表示采用合并提交中编号为 1 的父分支的更改。编号从 1 开始,通常 1 表示"主要"或"目标"分支,而 2 表示被合并进来的分支。

解决冲突

在 cherry-pick 过程中,如果新提交的更改与当前分支的更改发生冲突,Git 会停止 cherry-pick 过程,并让你解决冲突。解决冲突后,你需要执行以下命令来继续 cherry-pick 过程:

git add .  # 将解决冲突后的文件添加到暂存区  
git cherry-pick --continue  # 继续 cherry-pick 过程

如果你决定放弃 cherry-pick,可以使用以下命令:

git cherry-pick --abort

这将撤销 cherry-pick 操作,并将工作目录和暂存区恢复到 cherry-pick 之前的状态。

相关推荐
真就死难3 小时前
Git是什么
git
机械心8 小时前
代码管理git详细使用教程及最佳实践路径
git
hkj88089 小时前
Git 常用命令
git
dawnkylin14 小时前
通过 fork 为项目做出贡献
git·github
1379003401 天前
Git 设置代理
git
xiaodunmeng1 天前
sourcetree gitee 详细使用
git
LostSpeed2 天前
git,gitea - tool - creat Gitea Empty Rep Dir
git·gitea
前端郭德纲2 天前
vscode默认终端怎么设置成git bash
git·vscode·bash
近听水无声4772 天前
git 学习(基于Ubuntu和gitee)
git
2401_826097623 天前
同步&异步日志系统-日志落地模块的实现
c++·git·vim