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

相关推荐
爱钓鱼的程序员小郭10 分钟前
Git 使用文档
git
IT布道21 分钟前
[Git] 源码服务器主/备备份方案
运维·服务器·git
lpfasd12338 分钟前
Win11笔记本睡眠唤醒致命bug:NUL设备丢失致Git等工具瘫痪
git·bug
AI自动化工坊1 小时前
基于Git Worktree的OpenSwarm多Agent开发团队实践
git
墨倾许2 小时前
从零搭建运维学习环境(2026):WSL + Docker + Git + VS Code 完全指南
运维·git·学习·docker·容器·bash
蓝精灵没长耳朵2 小时前
Git系列
git
老四啊laosi2 小时前
Git(一)简介&&基本操作
git·基本操作
OYangxf2 小时前
Git分支管理
大数据·git·elasticsearch
【 STM32开发 】7 小时前
Git 安装 -- 图解教程
git
平凡码工人12 小时前
Git 安装流程和基础使用步骤 2026
git