git的merge和rebase操作

拿idea git示例。

feature分支是基于master拉出来的特性分支。从两个枝干分叉点开始往上看。

看枝干,黄色的枝干是master,目前在master上面有3个圆点,就是三次commit操作。(其中"master第2提交",是我用这个commit message commit了两次。其实一共我push了两次。所以这里的圆点,就是commit的操作次数)

紫色的枝干上,也有三个圆点,分别是feature:第一次提交、第二提交、第三次提交。

看右侧的标签,此时远端feature上,最新的push是"feature第三次提交"的数据。

在远端master上,最新的push数据是"master第2提交"。

下面分开来看各自分支的提交。


我们的目的是将master 分支上的最新提交,合到feature上。

标题 merge操作

merge:找到两个不同分支最后的提交,作为两个祖先,生成新的提交点。

分支切换到feature,点击master,进行 master 合入feature,操作之后是:

master最新的提交是"master第2提交", feature最新的提交是"feature第三次提交",所以merge就是基于这两个节点,生成了新的提交节点,就是最上面那个绿色分支的圆点。可以看到绿色分支是把这两个父节点连起来了,然后生成了新的节点。

注意看标签的名称,因为feature我还没有push,所以第一个标签显示的是本地的"feature",而远端origin/feature分支,在他的下面。

点开本次merge操作,在右边能看到两个父节点的提交信息:

rebase操作

rebase是,把另一个分支上面的节点,逐个摘下来放到分支上面。

点击操作之后(onto是表示到... 上面、在... 表面,所以rebase feature onto master,是把feature的节点,放到master上面),把feature上面的三次commit,都逐个的拼到了master后面,作为全新的feature。

注意,我们看到又新生成了三个feature的hash值。所以rebase会进行历史的修改。

rebase注意事项

永远不要在已推送到远程的公共分支上执行 rebase! 因为会造成历史信息的改变,其他人再拉取的时候,会造成大量的冲突。

总结:

merge:大家一起盖楼,往上加层,谁都不影响谁

rebase 公共分支:你偷偷把下面的地基拆了重盖,上面所有人的房子全塌

相关推荐
打不了嗝 ᥬ᭄7 小时前
Git 原理与使用
git·gitee
m0_614619069 小时前
花了一下午学 Git,整理了一份学习笔记
笔记·git·学习
AGV算法笔记11 小时前
解决Git> git add -A -- fatal: CRLF would be replaced by LF in Test/Test.cpp
git
Dontla12 小时前
VSCode插件Git Graph介绍(Git可视化管理分支、可视化Git)
ide·git·vscode
Echoo华地13 小时前
用git diff快速比较文件夹差异并生成报告
linux·git·unix·repository·diff·branch
勤劳打代码13 小时前
防微杜渐 —— 为什么一次 Sync 会变成一次 merge?
git·团队管理
dyxal14 小时前
Windows 下 Git 离线安装与 VS Code 便携版集成完全指南
windows·git·elasticsearch
K3v15 小时前
【git】自动化合并推送脚本
git·自动化
鹓于15 小时前
Android APK开发到发布全流程指南
git·github
花哥码天下16 小时前
Git 多远程仓库管理
git