git merge 和 rebase 和 cherry-pick 的区别

merge

git merge是用来合并两个分支的。

# 将b分支合并到当前分支
git merge b

cherry-pick

可以选择某一个分支中的一个或几个commit(s)来进行操作。

主要使用的场合:

  • 把弄错分支的提交移动到正确的地方
  • 把其他分支的提交添加到现在的分支

它解决的问题就是:在本地 master 分支上做了一个commit ( 38361a68138140827b31b72f8bbfd88b3705d77a ) ,如何把它放到 本地开发 old_cc 分支上?

例如,假设我们有个稳定版本的分支,叫v2.0,另外还有个开发版本的分支v3.0,我们不能直接把两个分支合并,这样会导致稳定版本混乱,但是又想增加一个v3.0中的功能到v2.0中,这里就可以使用cherry-pick了。

# 先在v3.0中查看要合并的commit的commit id
git log
# 假设是 commit f79b0b1ffe445cab6e531260743fa4e08fb4048b

# 切到v2.0中
git check v2.0

# 合并commit
git cherry-pick f79b0b1ffe445cab6e531260743fa4e08fb4048b

rebase

有点类似 git merge,但是两者又有不同,merge 适合那种比较琐碎的,简单的合并,系统级的合并还是用 rebase 吧。

打个比方,你有两个抽屉A和B,里面都装了衣服,现在想把B中的衣服放到A中,git merge 是那种横冲直撞型的,拿起B就倒入A里面,如果满了(冲突)再一并整理;而 git rebase 就很持家了,它会一件一件的从B往A中加,会根据一开始放入的时间顺序的来加,如果满了你可以处理这一件,你可以继续加,或者跳过这一件,又或者不加了,把A还原。

# 合并b
$ git rebase b
# 处理完冲突继续合并
$ git rebase --continue
# 跳过
$ git rebase --skip
# 取消合并
$ git rebase --abort

假设有两个分支,master 和 issue,一般流程如下:

$ git checkout issue
$ git rebase master
# 解决冲突
$ git add myfile.txt
$ git rebase --continue
# Applying: some text
$ git checkout master
$ git merge issue

如果觉得我的文章对您有用,请在支付宝公益平台找个项目捐点钱。 @Victor Aug 29, 2014

奉献爱心