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 之前的状态。

相关推荐
星源~9 小时前
tree 命令集成到 Git Bash:可视化目录结构的指南
git·单片机·物联网·嵌入式·项目开发
zhaqonianzhu10 小时前
git gerrit安装钩子
git·gerrit
这是个栗子10 小时前
【问题解决】VSCode终端中看不到Git-Bash
ide·git·vscode
悲伤小伞10 小时前
linux_git的使用
linux·c语言·c++·git
天机️灵韵12 小时前
云效DevOps vs Gitee vs 自建GitLab的技术选型
git·开源项目
荔枝吻18 小时前
【AI总结】Git vs GitHub vs GitLab:深度解析三者联系与核心区别
人工智能·git·github
mrbone1119 小时前
Git-git worktree的使用
开发语言·c++·git·cmake·worktree·gitab
小哈龙20 小时前
裸仓库 + Git Bash 搭建 本地 Git 服务端与客户端
开发语言·git·bash
GISer_Jing1 天前
Git协作开发:feature分支、拉取最新并合并
大数据·git·elasticsearch
高山莫衣1 天前
git rebase多次触发冲突
大数据·git·elasticsearch