标题上的两个命令:merge和rebase都是用来合并分支的。
这里不解释rebase命令,以及两个命令的原理,详细解释参考这里。
下面的内容主要说的是两者在实际操作中的区别。
分支就是便于多人在同一项目中的协作开发。比方说:每个人开发不同的功能,在各自的分支开发过程中互不影响,完成后都提交到develop分支。极大的提高了开发的效率。
每个人创建一个分支进行开发,当开发完成,需要合并到develop分支的时候,就需要用到合并的命令。
合并的时候,有可能会产生冲突。
冲突的产生是因为在合并的时候,不同分支修改了相同的位置。所以在合并的时候git不知道那个到底是你想保留的,所以就提出疑问(冲突提醒)让你自己手动选择想要保留的内容,从而解决冲突。
采用merge和rebase后,git log的区别,**merge命令不会保留merge的分支的commit**:

image
处理冲突的方式:
- (一股脑)使用`merge`命令合并分支,解决完冲突,执行`git add .`和`git commit -m'fix conflict'`。这个时候会产生一个commit。
- (交互式)使用`rebase`命令合并分支,解决完冲突,执行`git add .`和`git rebase --continue`,不会产生额外的commit。这样的好处是,‘干净’,分支上不会有无意义的解决分支的commit;坏处,如果合并的分支中存在多个`commit`,需要重复处理多次冲突。
git pull
和git pull --rebase
区别:git pull
做了两个操作分别是‘获取’和合并。所以加了rebase就是以rebase的方式进行合并分支,默认为merge。git merge
和 git merge --no-ff
的区别1、我自己尝试merge
命令后,发现:merge时并没有产生一个commit。不是说merge时会产生一个merge commit吗?
注意:只有在冲突的时候,解决完冲突才会自动产生一个commit。
如果想在没有冲突的情况下也自动生成一个commit,记录此次合并就可以用:git merge --no-ff
命令,下面用一张图来表示两者的区别:
image