git如何把分支提交的代码同步到另一个分支(git cherry-pick)

实际场景

在多版本项目开发中,大家应该经常会遇到需要把最新版本上开发的代码,同步到历史的版本中,或者是在发版后发现了问题,在最新版代码上解决了该问题,同时也需要把以前有问题的版本给解决掉,再把解决过的发个版给客户使用,这时分别在不同版本上改代码会很麻烦,如果能把一个版本上解决好的代码,直接同步到另一个版本就好了,git cherry-pick就能满足这个需求,下面给大家介绍一下。

git cherry-pick 是同步哪些代码

  • git cherry-pick 同步的是当前提交记录中的代码,就算你的同一个文件的版本1和版本2中还有其他差异代码也不会同步。

git cherry-pick同步原理

  • 假设有两个分支:master分支,develop分支
master   a-b-c
develop  a-b-c-d-e-f
  • 现要将develop提交的 e 记录,同步到master
master   a-b-c-e
develop  a-b-c-d-e-f
  • 同步后,只会把 e 记录所有操作同步到master,此时只多了 e 记录的内容。

方式1:使用git命令进行同步

  • 假设有两个分支:master分支,develop分支
master   a-b-c
develop  a-b-c-d-e-f

只同步一条记录 e

  • 首先需要把代码切到需要同步的分支上,即master分支
git checkout master
  • 查看 e 记录的commit id(提交记录 id ,下面简称 eid)
git log
  • 执行同步操作,把 e 记录同步到master分支
git cherry-pick eid
  • 如果同步错误,可取消之前的cherry-pick
git cherry-pick --quit

同步多条记录 d,e,f

  • 首先需要把代码切到需要同步的分支上,即master分支
git checkout master
  • 查看 d,e,f 记录的commit id(提交记录 id ,下面简称 did、eid、fid)
git log
  • 执行同步操作,把 d,e,f 记录同步到master分支
#写法1:^表示包括左边的,即[did,fid]
git cherry-pick did^..fid 
#写法2:不包括左边,即(did,fid]
git cherry-pick cid..fid 
  • 如果同步错误,可取消之前的cherry-pick
git cherry-pick --quit

方式2:使用Idea进行同步

  • 首先切到master分支
    在这里插入图片描述
  • 打开日志提交记录,在对应记录上点击右键,选择Cherry-Pick即可
    在这里插入图片描述
  • 15
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值