git cherry-pick

git cherry-pick 命令

挑选部分的commit来提交的指令

  • 挑选一个commit-id合并:

    git cherry-pick commit-id

  • 挑选多个commit-id合并:

    git cherry-pick commit-idA commit-idB

  • 挑选连续的多个commit-id合并

    git cherry-pick commit-idA..commit-idB

    该指令是将从commit-idA开始到commit-idB之间的所有commit-id提交记录都合并过来,需要注意的是,commit-idA必须比commit-idB提前提交,也就是说在被挑选的分支上,先有的commit-idA,然后才有的commit-idB。不包括commit-idA,若需要包含提交commit-idA,可以用:

    git cherry-pick commit-idA^..commit-idB

合并冲突的情况:

  1. 第一种操作:继续合并--continue

    • 人为解决冲突文件,然后提交到暂存区

      git add.

    • 使用命令继续执行

      git cherry-pick --continue

  2. 第二种操作:放弃合并,回归原始状态--abort

    • git cherry-pick --abort
  3. 第三种操作:放弃合并,保留车祸现场状态--quit

    • git cherry-pick --quit

分支转移提交命令,将指定的提交应用于其他分支

git cherry-pick < commitHash >

可以将指定的提交commitHash,应用于当前分支,这会在当前分支产生一个新的提交,哈希值也不一样

git cherry-pick命令的参数,不一定是提交的哈希值分支名也是可以的,表示转移该分支的最新提交:

git cherry-pick feature (将feature分支的最近一次提交,转移到当前分支)

应用:

在开发中,我不小心将代码写到了uat分支并提交了,而不是自己创建的分支,这个时候就可以使用git cherry-pick来转移提交

  1. 首先,使用git log来查看历次提交,可得到提交错误的流程的哈希值(在uat分支)

  2. 切回本地分支,执行**git cherry-pick 11ec8a081b65307396305f3932b6eb75b378924b(哈希值)**命令,可以把提交错误的分支应用于本地提交

相关推荐
狂炫冰美式7 小时前
人均配了AI, 为什么公司还是没变快? 🤔 本质还是分布式系统问题
前端·后端·架构
乘风gg8 小时前
多 Agent 不是万能的!搞懂这 5 个原则,少走 1 年弯路!
前端·agent·ai编程
猩猩程序员9 小时前
Vercel 推出 Agent 框架 Eve:让 AI Agent 像写 Web 应用一样简单
前端
爱读源码的大都督9 小时前
Claude Code源码分析(三):为什么系统提示词中需要有tools呢?
前端·人工智能·后端
爱勇宝9 小时前
Claude Code 被曝暗藏“隐形检测”代码:封代理不是最可怕的,可怕的是你根本不知道它在干什么
前端·后端·程序员
小牛不牛的程序员9 小时前
我用 Claude Code 半天撸完了一个完整网站,AI 编程到底提升了多少效率?
前端
东风破_9 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
ITOM运维行者10 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
monologues10 小时前
深入 Vue 3 源码:响应式系统的精妙设计与编译优化
前端
hunterandroid10 小时前
Paging 3 分页:从手动分页到声明式加载
前端