git cherry-pick 命令

git cherry-pick 命令就像一把精准的"手术刀",允许你将一个或多个**特定的提交(commit)**从任意分支应用到当前分支,而无需合并整个分支的历史。

🎯 核心用法

  1. 找到目标提交的哈希值 (Commit Hash)

    首先,你需要找到想要复制的那个提交的哈希值

    复制代码
    1git log source-branch --oneline

    这会列出源分支的提交历史,例如 a1b2c3d Fix login bug

  2. 切换到目标分支

    切换到你想要应用这个提交的分支

    复制代码
    1git checkout target-branch
  3. 执行 cherry-pick

    使用提交的哈希值执行命令

    复制代码
    1git cherry-pick a1b2c3d

    执行成功后,Git 会在当前分支创建一个新的提交,其内容与源提交相同,但拥有全新的哈希值。

📦 批量操作

  • 挑选多个不连续的提交

    只需将多个提交的哈希值用空格隔开

    复制代码
    1git cherry-pick <hash1> <hash2> <hash3>
  • 挑选一段连续的提交

    使用 起始哈希..结束哈希 的语法。注意,这个范围默认不包含 起始哈希,但包含结束哈希

    复制代码
    1git cherry-pick <hash-A>..<hash-B>

    如果需要包含起始哈希 A,可以使用 A^..B 的写法。

⚙️ 常用参数

参数 命令示例 说明
-n / --no-commit git cherry-pick -n <hash> 只将更改应用到工作区和暂存区,不自动创建提交。
-e / --edit git cherry-pick -e <hash> 打开编辑器,允许你修改提交信息。
-x git cherry-pick -x <hash> 在提交信息末尾追加来源信息,如 (cherry picked from commit <hash>),便于追溯。
-m git cherry-pick -m 1 <hash> 当目标提交是一个合并提交时使用,用于指定采用哪个父分支的变更。

⚠️ 处理冲突

cherry-pick 本质上是一次合并操作,因此可能会遇到代码冲突。

  1. 解决冲突:当 Git 提示冲突时,手动编辑冲突文件,保留你需要的代码。

  2. 标记解决 :解决完所有冲突后,使用 git add <文件名> 将文件标记为已解决。

  3. 继续操作

    复制代码
    1git cherry-pick --continue
  4. 放弃操作 :如果想中途放弃,可以执行:

    复制代码
    1git cherry-pick --abort

🤔 典型应用场景

  • 紧急 Bug 修复 :在 develop 分支修复了一个严重 Bug,需要立即将这个修复同步到 releasemain 分支,但又不想引入 develop 分支上其他未完成的开发内容。
  • 选择性功能同步 :某个功能分支 (feature) 中的一个提交非常有用,你只想把这个提交应用到主分支,而不是合并整个功能分支。
  • 跨分支应用补丁:将某个分支上的代码改进或补丁,精准地应用到其他多个分支上。
相关推荐
尽兴-2 小时前
Git 分支管理核心命令科普指南
数据库·git·分支管理·代码仓库
小陈工2 小时前
Python Web开发入门(一):虚拟环境与依赖管理,从零搭建纯净开发环境
开发语言·前端·数据库·git·python·docker·开源
Sakuyu434683 小时前
Git-GitLab-JenKins
git·gitlab·jenkins
console.log('npc')3 小时前
【无标题】
git
晨非辰3 小时前
Git版本控制速成:提交三板斧/日志透视/远程同步15分钟精通,掌握历史回溯与多人协作安全模型
linux·运维·服务器·c++·人工智能·git·后端
shughui4 小时前
2026Git 下载、安装、使用完整教程(附安装包)
git·github·代码仓库
Moshow郑锴12 小时前
Git如何上传目录到github项目进行初始化
git
春日见21 小时前
GIT操作大全(个人开发与公司开发)
开发语言·驱动开发·git·matlab·docker·计算机外设·个人开发
Ama_tor1 天前
将本地的 Electron 项目上传到 Gitee(码云)的 Git 操作流程
git·electron·gitee