今天遇到一个需求,因为业务原因,现已开发的部分功能,暂时不上线,只上线部分功能,但我们的所有功能都在同一个分支上,于是就需要把部分功能代码分离出来,一起来看看吧!

一、合并单个commit

首先,我们需要把A分支上提交的部分代码,放在B分支上

git checkout B  // 切换到B分支
git cherry-pick 43aea9af  // 把某一次的commit合并到B分支,其中’43aea9af‘是某次commit提交记录的ID
git push origin B  // 把分支B推送到远程仓库

二、合并连续的多个commit

如果我们想要合并多个连续的commit,用上面的第一种方法,显然效率不高,可以使用一下方法:
比如我们再A分支上有43aea9af70dfeec2a连续的10个commit要合并到B分支上

  1. 首先基于A分支创建一个临时分支temp,并指明新分支的最后一个commit
git checkout -b temp 70dfeec2a
  1. temp分支上的从43aea9af到最后一个commit,也就是70dfeec2acommit合并到B分支上
git rebase --into B 43aea9af^

版权声明:本文为Liberty_yes原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/Liberty_yes/article/details/127238234