当前位置: 首页 > news >正文

git的 Rebase

理解

git rebase 的直白意思是:把一段提交“挪到”另外一个基点上重放(重新应用),从而改写历史、让分支历史变直(线性)。
 

它到底做了什么?

假设你有:

A --- B --- C   (main)\D --- E (feature)

在 feature 上执行:

git checkout feature
git rebase main

Git 会把 D、E 这两个提交从原来的基点 B“摘下来”,再依次应用到 C 的后面

A --- B --- C -------- D' --- E' (feature)
 

D'、E' 是“重放”后的新提交(哈希变了),看起来像把 feature“挪到”main 最新位置继续写,从而形成线性历史


和 merge 的区别

  • merge:把两条线“合并”,产生一个合并提交不改历史

  • rebase:把你的提交“搬到”对方后面,改写历史,历史更整洁。

简记:

  • 想要干净一条线rebase

  • 想要保留真实分叉/合并关系merge


常见用法

  1. 1、把功能分支移到主分支最新位置

git checkout feature
git fetch origin 
git rebase origin/main

然后再合并/推送,减少冲突。

  1. 2、交互式 rebase(整理历史)

git rebase -i HEAD~5

        在弹出的列表里可以:

  •       pick 使用

    •    reword 改提交信息

      • squash/fixup 合并多个提交

      • drop 丢弃某次提交

      • edit 暂停在某次提交(常用于“删提交但保留代码”:git reset --mixed HEAD^ 然后重提)

  1. 把某次提交的父链改到别处

git rebase --onto new-base old-base branch

意思是:把 branch 上 从 old-base 之后 的那段提交,搬到 new-base 上。


什么时候用 / 不用

适合:

  • 让历史更直(线性历史、易读)。

  • 本地分支的提交还没分享给别人(还没 push 或别人没基于它工作)。

  • 整理提交(合并、改信息、删除某些提交)。

避免:

  • 已经被多人拉取/基于的公共分支(如远程 main),rebase 会改哈希,会给同事带来同步成本。

  • 不熟悉时直接在远端受保护分支上改历史。


推送注意

rebase 改了提交哈希,推送时需要强推

git push --force-with-lease 

--force-with-lease 比 --force 安全,能避免覆盖别人新提交)


一句话总结

  • rebase = 改基重放:把你的提交“挪”到新的基点上,改写历史,让提交串更直更干净。

  • 本地整理历史、跟进主分支最新进展、删除/合并历史提交时,用 git rebase 最合适。

  • 改历史要谨慎:公共分支少用,推送用 --force-with-lease

http://www.dtcms.com/a/499267.html

相关文章:

  • 第8篇 QT联合halcon12在vs2019搭建环境开发图像处理
  • 【小白笔记】最大交换 (Maximum Swap)问题
  • CentOS安装Node.js
  • 深入解析MCP:从基础配置到高级应用指南
  • 佛山网站建设服务wordpress 不能更换主题
  • Process Monitor 学习笔记(5.13):从 0 到 1 的排障剧本清单(可复用模板)
  • Fluent 重叠网格+UDF NACA0012翼型摆动气动仿真
  • 深圳网站建设 设计卓越迈wordpress一键采集文章
  • 理想汽车Java后台开发面试题及参考答案(下)
  • python|if判断语法对比
  • 全链路智能运维中的实时流处理架构与状态管理技术
  • 排序算法:详解快速排序
  • 安阳哪里做360网站科技感十足的网站
  • UV 紫外相机在半导体制造领域的应用
  • 突破亚微米光电子器件制造瓶颈!配体交换辅助打印技术实现全打印红外探测器
  • 可见光工业相机半导体制造领域中的应用
  • require和 import是两种不同的模块引入方式的区别
  • 半导体制造工艺基本认识 五 薄膜沉积
  • 矩阵及其应用
  • **发散创新:探索零信任网络下的安全编程实践**随着信息技术的飞速发展,网络安全问题日益凸显。传统的网络安全防护方式已难以
  • 网络营销方案毕业设计安卓手机性能优化软件
  • 建设企业网站价格建设银行北京市财满街分行网站
  • (Kotlin高级特性一)kotlin的扩展函数和属性在字节码层面是如何实现的
  • Spring Boot 3零基础教程,WEB 开发 静态资源默认配置 笔记27
  • 【论文精度-2】求解车辆路径问题的神经组合优化算法:综合展望(Yubin Xiao,2025)
  • 赣州哪里做网站域名注册备案
  • windows双系统下 ubutnu 20.04 启动项出问题无法进入ubuntu 20.04的解决方法
  • MQTT 协议全面学习笔记
  • 加权分位数直方图:提升机器学习效能的关键技术
  • 做分析图网站无锡seo优化