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 公共分支:你偷偷把下面的地基拆了重盖,上面所有人的房子全塌

相关推荐
___波子 Pro Max.4 小时前
Git 分支切换
git
win x4 小时前
一篇搞懂Git基础操作
linux·git
一个有温度的技术博主5 小时前
网安实验系列五:.git源代码泄露
git
吴声子夜歌6 小时前
TypeScript——索引类型、映射对象类型、条件类型
git·ubuntu·typescript
吴声子夜歌6 小时前
TypeScript——局部类型、联合类型、交叉类型
javascript·git·typescript
i建模14 小时前
安装 `openclaw@2026.3.1` 时遇到了 Git 仓库访问权限问题
git
freewlt16 小时前
git配置文件名称大小写
git
小熊熊知识库18 小时前
Git工具使用
git
春夜喜雨21 小时前
Git 分支merge合并常用步骤与命令操作
git