git rebase 重建清爽的历史提交

前言

在进行代码评审时遇到分支上有多个commit信息,对于评审者来说是非常头疼的,因为太混乱了。遇到这样的情况,就需要让开发人员把commit压缩一下,简单来说就是将多个commit合并为一个,这样看起来就比较整洁了,那git rebase是如何做到的呢?

git rebase 作用

git rebase 命令有两个作用:

  1. 将当前分支的更改重新应用到目标分支上,即变基。
  2. 对当前分支的历史提交进行更改,这里称之为交互式变基。

变基

变基具体来说就是:如果你正在一个分支上工作,想要将这些更改合并到主分支master上,但是主分支上已经有了新的提交,此时使用 rebase 可以让当前分支的更改应用到最新的主分支上。如下图

交互式变基

交互式变基时,可以使用不同的命令来修改提交历史:

  • p, pick <提交> :使用提交
  • r, reword <提交> :使用提交,但修改提交说明
  • e, edit <提交> :使用提交,进入 shell 以便进行提交修补
  • s, squash <提交> :使用提交,但融合到前一个提交
  • f, fixup <提交> :类似于 "squash",但丢弃提交说明日志

commit压缩/合并操作

所以,上述"将多个commit合并为一个"就是通过交互式变基完成的。具体操作如下:

  • 执行 git rebase -i HEAD~n ,n为你想要合并的提交数量,例如我输入git rebase -i HEAD~6 ,会出现下图的交互页面。
  • 将下面5个pick改为squash并保存。
  • 执行git push -f

通过上面的3步就完成了commit合并/压缩。效果如下图:

总结

开发过程中,为了避免代码丢失或其他因素,一次功能的完成避免不了多次提交。写好提交不仅可以帮助开发人员理清代码的逻辑,而且,整洁的提交记录也可以提高评审效率。所以,尽可能在一个提交中完成一个完整的功能。

相关推荐
二宝哥12 分钟前
大数据之yum安装git
git
牛奶咖啡131 小时前
Git实践——git远程仓库操作
git·git远程仓库的创建·github创建仓库·git将本地仓库推送到远程仓库·使用git克隆远程仓库到本地·git分支的创建与合并·git冲突的产生与解决
随风,奔跑2 小时前
Git学习笔记
笔记·git·学习
Gary Studio3 小时前
Git vscode 插件推荐
ide·git·vscode
StackNoOverflow4 小时前
IDEA + Git + Gitee 全流程实战:从安装、提交到解决冲突
git·gitee·intellij-idea
淘矿人17 小时前
从0到1:用Claude启动你的第一个项目
开发语言·人工智能·git·python·github·php·pygame
lpfasd12318 小时前
Git/Gitee/GitHub 3 个安全凭证详解
git·gitee·github
李日灐1 天前
< 7 > Linux 开发工具:git 版本控制器 和 cgdb/gdb 调试器
linux·运维·服务器·开发语言·git·调试器·gdb/cgdb
Gust of wind1 天前
idea结合git和Gitee的初步使用
git·gitee·intellij-idea
夜七少eleanor1 天前
【Git】2026全图文详解安装教程
git