Git合并分支rebase和merge区别

Git可视化工具下载:Git - GUI Clients

合并前分支:

Merge之后的结果:

rebase之后的结果:

1 Git分支合并rebase和merge区别
  • merge工作原理:假如在master分支上因为业务需要临时拉出个分支叫dropdown,现在主分支master有新的提交,dropdown分支也有提交,业务开发完成要进行分支合并,此时两个分支的共同祖先(即拉分支的节点)和两个分支中的最新提交进行一个三方合并,合并中修改的内容生成一个新的commit,这个merge的效果简单来说就是合并两个分支生成一个新的提交。
  • rebase工作原理:dropdown分支合并到master分支上,执行rebase后依次将当前的分支提交合并到目标分支上,然后将原分支上已提交的commit删除,也就是分支线log日志记录信息被删掉了只保留一个主的分支提交记录。
2 merge OR rebase:

(1)可以看出merge结果能够体现出时间线,但是rebase会打乱时间线。

(2)rebase看起来比较简洁,merge看起来不太简洁。

(3)最终结果是都把代码合起来了,所以具体怎么使用这两个命令看项目需要。

3 常用命令缩写
  • git pull 拉取代码,git pull 相当于是 git fetch + git merge,
  • git pull -r,也就是git pull --rebase,相当于 git fetch + git rebase
4 应用场景
  • 不要在公共分支使用rebase
  • 本地和远端对应同一条分支,优先使用rebase,而不是merge
相关推荐
草莓熊Lotso3 小时前
Git 本地操作入门:版本控制基础、跨平台部署与仓库核心流程
开发语言·人工智能·经验分享·git·后端·架构·gitee
计算衎11 小时前
git仓库中的.git目录 , .gitattributes、.gitignore、.gitmodules、.modules文件作用与讲解
git·git bash·文件结构
Murphy_lx14 小时前
git工作流程
git
Elias不吃糖14 小时前
Git常用指令合集
linux·git
melt_102617 小时前
【gitee账号设置】git多个账号在多台电脑上使用
git·gitee·git账号管理
南宫真汀19 小时前
微信小程序项目上传到git仓库(完整操作)
git
夜月yeyue20 小时前
嵌入式开发中的 Git CI/CD
c++·git·单片机·嵌入式硬件·ci/cd·硬件架构
真人不梦21 小时前
Lazygit: 从0到熟练使用,你需要的都在这里
git·github
denggun123451 天前
图片上传git时压缩
git·ios·objective-c·iphone·xcode
行走的陀螺仪1 天前
git-旧项目继续开发新功能,同时还要维护线上版本
git·git push·git commit·git 协同开发