幻灰龙 2021-07-09 00:03 采纳率: 90.9%
浏览 164
已结题

git 如何 合并其他分支的代码

项目开发中 git 的分支一般会有三个分支:

  • 开发分支,例如 dev
  • 测试分支,例如 test
  • 发布分支,例如 pub

正常情况下,应该在不同的环境下使用对应的分支

  • 开发环境运行开发分支的代码
  • 测试环境运行测试分支的代码
  • 正式环境使用发布分支的代码

开发中的常见合并顺序是从 dev->test->pub 的合并顺序:

  • 合并开发分支的代码到测试分支
    • git checkout test
    • git merge dev
    • git push
    • 切换回开发分支 git checkout dev
  • 测试通过后,合并测试分支的代码到发布分支
    • git checkout pub
    • git merge pub
    • git push
    • 切换回开发分支 git checkout dev

但是有一次切换到test分支后,忘记切回dev分支,于是在上面修改了几个提交,产生了几个commit,这个时候应该如何正确处理?

  • 写回答

2条回答 默认 最新

  • 幻灰龙 2021-07-09 00:09
    关注

    一般的解决办法是:

    git log -n 10 查看test分支上的最新10个提交,例如从A开始新增了3个提交:

    • D
    • C
    • B
    • A

    其中BCDtest分支上新产生的commit,那么可以使用 git cherry-pick 命令。

    • 先切到 dev 分支:git checkout dev
    • 现在可以使用 git cherry-pick B C D 一次性把 BCD 三个committest分支提取到dev分支
    • 也可以使用范围提取:git cherry-pick A..D ,注意:此时 A 并不被包含在提取commit范围内,也就是左开右闭的区间范围。

    你有更好的方式么?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • blkq 2021-07-09 00:21
    关注

    就是这样干,如果代码差异大,merge的时候就要小心了

    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月12日
  • 已采纳回答 7月9日
  • 修改了问题 7月9日
  • 修改了问题 7月9日
  • 展开全部

悬赏问题

  • ¥80 关于海信电视聚好看安装应用的问题
  • ¥15 vue引入sdk后的回调问题
  • ¥15 求一个智能家居控制的代码
  • ¥15 ad软件 pcb布线pcb规则约束编辑器where the object matpcb布线pcb规则约束编辑器where the object matchs怎么没有+15v只有no net
  • ¥15 虚拟机vmnet8 nat模式可以ping通主机,主机也能ping通虚拟机,但是vmnet8一直未识别怎么解决,其次诊断结果就是默认网关不可用
  • ¥20 求各位能用我能理解的话回答超级简单的一些问题
  • ¥15 yolov5双目识别输出坐标代码报错
  • ¥15 这个代码有什么语法错误
  • ¥15 给予STM32按键中断与串口通信
  • ¥15 使用QT实现can通信