【GIT】TortoiseGit的变基(Rebase)操作

devtools/2024/11/26 7:42:47/

TortoiseGit 中,变基(Rebase) 是一个 Git 的高级操作,用来重新整理分支的提交记录,使它们的历史更加线性化。


1. 什么是变基?

变基的主要作用是将一个分支上的提交“移动”到另一个分支的末尾,从而重新整理提交历史,使其更加线性化。

  • 普通合并(Merge):直接将两个分支的提交历史保留并合并,可能会导致提交历史变得复杂(如有分叉)。
  • 变基(Rebase):将当前分支上的提交应用到目标分支的最新提交之后,使提交历史变得线性。
举例说明:

假设你的仓库有两个分支:mainfeature,它们的提交历史如下:

main:    A --- B --- C\
feature:            D --- E

如果执行变基操作:将 feature 分支变基到 main 分支,变基后的历史变为:

main:    A --- B --- C --- D' --- E'
  • D'E' 是重新应用的 DE 提交,生成了新的提交哈希。
  • 变基的结果是提交历史变得更清晰,适合协作开发或代码审查。

2. 变基的常见应用场景

  1. 保持提交历史整洁

    • 避免分支之间的复杂分叉,使历史更线性。
    • 便于代码审查或浏览历史记录。
  2. 同步远程分支的最新变化

    • 如果 main 分支发生变化,而 feature 分支落后了,可以使用变基将 feature 的提交移动到 main 的最新状态。

3. 变基和合并的区别(图解)

合并(Merge):保留分支历史

执行 git merge 时,历史记录会保留分叉结构:

Before Merge:main:    A --- B --- C\
feature:            D --- EAfter Merge:main:    A --- B --- C ------ M\         /
feature:            D --- E
  • M 是合并提交,包含 mainfeature 的变更。

变基(Rebase):线性化历史

执行 git rebase 时,feature 分支的提交会被重新“应用”到 main 的末尾,生成新的提交:

Before Rebase:main:    A --- B --- C\
feature:            D --- EAfter Rebase:main:    A --- B --- C --- D' --- E'
  • D'E' 是新的提交,具有新的哈希值。

4. 在 TortoiseGit 中执行变基

以下是如何在 TortoiseGit 中完成变基操作的步骤:

准备工作
  • 确保已安装 TortoiseGit 并正确设置。
  • 打开包含 Git 仓库的目录。
执行步骤
  1. 打开变基功能

    • 在文件资源管理器中,右键点击你的 Git 仓库根目录。
    • 选择 TortoiseGit > Rebase...
  2. 选择变基目标分支

    • 在弹出的对话框中,选择要变基到的目标分支(例如 main)。
    • 确保当前分支是你想变基的分支(例如 feature)。
  3. 查看变基计划

    • TortoiseGit 会显示变基操作的计划,包括哪些提交会被重新应用。
    • 确认后点击 Start Rebase
  4. 解决冲突(如果有)

    • 如果变基过程中发生冲突,TortoiseGit 会提示你解决冲突。
    • 手动解决冲突后,右键选择 TortoiseGit > Resolve...,然后继续变基。
  5. 完成变基

    • 如果变基操作成功,TortoiseGit 会显示操作完成的提示。

5. 注意事项

  1. 变基会更改提交历史

    • 变基后,提交的哈希值会改变,因此请避免对已推送到远程的分支进行变基操作。
    • 如果必须对远程分支变基,请通知团队成员以避免冲突。
  2. 合并还是变基的选择

    • 合并(Merge):保留分支历史,适合正式发布或记录完整开发过程。
    • 变基(Rebase):简化历史,适合清理提交历史或同步分支。
  3. 备份代码

    • 在进行变基前,确保本地分支的代码已保存或备份,以防止数据丢失。

小结

变基(Rebase) 是一种重新整理分支提交历史的工具,能让提交历史更清晰线性。在 TortoiseGit 中,变基操作通过图形界面非常直观,适合需要维护代码历史整洁的场景。

补充 变基操作

变基


http://www.ppmy.cn/devtools/137060.html

相关文章

观察者模式和发布订阅模式

文章目录 手写观察者模式手写发布订阅模式 观察者模式 Subject 和 Observer 直接绑定,中间无媒介。如点击事件,事件直接和按钮进行绑定。 发布订阅模式 Publisher 和 Observer 相互不认识,中间有媒介。如在 A 组件中绑定一个事件&#xff…

SpringBoot(三十六)SpringBoot使用sentinel自定义注解实现限流

前边我们学习了阿里的限流工具sentinel。她是有一个SentinelResource注解可以使用的,但是呢,使用SentinelResource注解需要链接sentinel控制台,在控制台中创建对应的规则。 再在对应的方法中使用SentinelResource注解来配置功能。 但是呢&…

python操作Elasticsearch

使用elasticsearch 6.x版本,操作es数据。 #! -*- coding:utf-8 -* import timefrom elasticsearch import Elasticsearch, helpersclass EstUtil:_instance Nonedef __new__(cls, *args, **kwargs):if not cls._instance:cls._instance super(EstUtil, cls).__ne…

【论文笔记】Number it: Temporal Grounding Videos like Flipping Manga

🍎个人主页:小嗷犬的个人主页 🍊个人网站:小嗷犬的技术小站 🥭个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。 基本信息 标题: Number it: Temporal Grou…

STM32H7开发笔记(2)——H7外设之多路定时器中断

STM32H7开发笔记(2)——H7外设之多路定时器中断 文章目录 STM32H7开发笔记(2)——H7外设之多路定时器中断0.引言1.CubeMX配置2.软件编写 0.引言 本文PC端采用Win11STM32CubeMX4.1.0.0Keil5.24.2的配置,硬件使用STM32H…

java charAt()返回数值型 详解

Java 中 charAt() 返回数值型详解 在 Java 中,charAt() 方法返回的是 char 类型,它代表的是字符,但字符在计算机中也有对应的数值表示(ASCII 或 Unicode 编码)。通过将 char 类型转换或直接参与计算,我们可…

emacs入门命令、android-studio和Android Gradle plugin(AGP)版本对照、zulu网页查找jdk11最新版下载脚本

emacs入门命令 ubuntu 22.04下emacs基本操作 sudo apt install -y emacs 图形化emacs | 文本化emacs --no-window-system, 快捷键Altx(M x)执行命令: shell #打开交互式shell终端 #emacs控制shell更精确 term #打开交互式终端(默认/bin/bash) #emacs几乎不能控制…

智控水利:道品科技农业灌区自动化闸门引领农业灌溉新变革

一、引言 农业灌溉作为农业生产的关键环节,直接影响着农作物的生长、产量与质量。在传统农业灌区中,闸门的操作主要依赖人工,这种方式在当今科技飞速发展的时代背景下,暴露出诸多弊端。道品科技农业灌区自动化闸门的出现&#xff…