实际场景
在多版本项目开发中,大家应该经常会遇到需要把最新版本上开发的代码,同步到历史的版本中,或者是在发版后发现了问题,在最新版代码上解决了该问题,同时也需要把以前有问题的版本给解决掉,再把解决过的发个版给客户使用,这时分别在不同版本上改代码会很麻烦,如果能把一个版本上解决好的代码,直接同步到另一个版本就好了,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即可