成为git砖家(9): rebase进阶: 拆分commit为多个

问题描述

当一次性 git add 了多个修改点, 并且快速的执行了 git commit 后, 你觉得有点懊恼: 明明可以独立为两次或多次 commit, 揉在一块导致历史记录不太清晰。

比如我在 nn1 这个练手项目中, 最近一次 commit, 增加了三个函数:

  • evaluate()
  • test_softmax()
  • accuracy()

git commit 后我后悔了,想要拆解为3次 commit,每次一个函数。

我们知道,对于已经存在的多个commit如果要合并起来,那么 rebase 是相当简单的。拆分 commit 呢? 也是可以用 rebase 来做的,用到的是 edit 这个动作。随后恢复暂存区,重新按需add和commit代码。

具体操作

  1. 备份现有代码到新的分支
    这一步是防止 git 操作失误。 其实熟练了可以省略,因为后续修改如果中途不满意可以 git rebase --abort
bash 复制代码
git checkout backup
  1. rebase到需要修改的commit的前一次commit

例如我最近一次 commit 需要被拆分, 它是 HEAD; 它的上一次commit用 HEAD~ 来表示:

bash 复制代码
git rebase -i HEAD~
  1. 把 edit 改为 pick
bash 复制代码
pick f29f90e 理解argmax; 理解accuracy

改为

bash 复制代码
edit f29f90e 理解argmax; 理解accuracy
  1. 恢复整个git工作区到文件已经修改了、尚未 git add 的状态

    复制代码
        --mixed
            Resets the index but not the working tree (i.e., the changed
            files are preserved but not marked for commit) and reports what
            has not been updated. This is the default action.
bash 复制代码
git reset HEAD~
  1. 手动添加文件中的一部分
    可以使用 git add -p xxx_file, 也可以用 vscode 图形界面操作, 选中代码区域后右键选择 Staging Selected Ranges
  1. 执行 git status 查看内容

确实生效了,增加了一个新的 commit "理解 argmax":

  1. 重复 git add, git commit 动作, 直到满意

  2. 执行 git commit --continue, 来告诉 git 你完成了 rebase 操作

  3. 最终查看效果

相关推荐
我会冲击波5 小时前
功能分支落后于develop太多,需要把开发分支合并到功能分支吗?
git·intellij idea
C++ 老炮儿的技术栈19 小时前
在 Scintilla 中为 Squirrel 语言设置语法解析器的方法
linux·运维·c++·git·ubuntu·github·visual studio
余很多之很多1 天前
命令行和neovim的git操作软件-lazygit
git
猫头虎1 天前
GitHub下载教程:2025年最新详解从GitHub上传、下载文件、子目录与完整项目【图文教程】
git·svn·gitee·开源·github·gitea·gitcode
i建模1 天前
将远程 main 分支同步到 develop 分支的完整指南
git
即使再小的船也能远航2 天前
【Git】实用Git操作指南:从入门到高效协作
git
<但凡.2 天前
Git 完全手册:从入门到团队协作实战(4)
git·bash
SugarPPig2 天前
Git 创建一个完全没有提交历史的 master 分支
git
lb29173 天前
git的使用,推送仓库github
git·github
躲在云朵里`3 天前
Git的使用
大数据·git·elasticsearch