作者 | 梁唐

来源 | TechFlow(ID:techflow2019)

头图 |  CSDN 下载自东方IC

大家好,今天我们来聊聊 git 当中一个很重要的功能——历史记录的修改。

有的时候我们会突然发现某个地方需要修改,最常见的某个不应该被提交的文件被提交了进来。我们希望它不只是在后续的版本当中不再出现,而是希望整个从 git 仓库当中移除掉。这个时候我们就需要修改 git 之前的历史记录。这个时候应该怎么办呢?

不要着急,git 当中有很多的手段可以修改之前的历史提交记录。

修改最后一次提交

这一点我们在之前的文章当中曾经提到过,如果我们只是想要修改最后一次的提交记录,这是比较简单的。我们只需要直接修改我们想要修改的部分,在提交的时候加上一个参数 --amend 即可。

git commit --amend

amend 的意思是补丁,它可以把我们这一次的修改合并到上一条历史记录当中,而不会产生一个新的 commit 记录。运行之后,它会打开一个 vim 编辑器,我们还可以修改上一次 commit 时输入的提示信息。

我们使用 git log 检查的话,会发现历史记录的修改时间还是上一次的时间。看起来就好像什么也没有发生过一样,悄无声息地就改掉了。

修改多个信息

--amend 虽然好用,但是它只能修改最后一次的提交信息,如果我们想要修改的提交记录在那之前,我们应该怎么办呢?

git 当中并没有提供直接的工具来实现这一点,不过我们可以使用 rebase 来达成。我们可以加上-i进行交互式地变基,我们可以在任何想要的修改完成之后停止,也可以添加文件或者是做其他想要做的事情。但是我们变基的目标不是某一个分支而是当前分支的某一个历史节点,所以我们需要提供一个具体的 commitid 或者是指针位置。

git rebase -i 的功能非常强大,我们几乎可以使用它来完成所有一切我们想要完成的事情。

比如我们想要修改倒数第二次提交,我们可以执行 git rebase -i HEAD~3。也就是以倒数第三个节点作为基准节点执行变基,这时候git会进入一个vim窗口,在这个窗口当中我们可以看到最近的三次提交记录。

首先我们可以看到上面的三行就是我们可以修改的三个 commit,分别展示的是要执行的操作以及 commitid 以及 commit message。这里的操作默认的是 pick,也就是使用该 commit。关于我们可以执行的操作 git 在下方也给了充分的提示,其中比较常用的有 pick、edit 以及 squash。

这一次我们想要做的是修改提交记录,所以我们应该执行 edit,我们把想要修改的 commit 前的 pick 改成 edit。比如这样:

退出之后,git 会自动带我们回到我们选择edit的分支提交之后的版本。我们进行我们想要的修改,这里我在第15篇文章当中加上了一行:尝试 rebase。之后再使用 git add 以及 git commit --amend 进行修改提交结果。

再之后我们执行 git rebase --continue,把剩下要应用的变更应用完成。

一切都结束之后,我们可以使用一下 git show 命令查看一下我们修改的 bee9ce3 这个 commit 的记录。可以看到已经多了这一行,说明我们的修改成功了。

顺序变更、合并、拆分

1、顺序变更

我们不仅可以修改某一次 commit 当中的内容,还可以修改这些 commit 的相对顺序,以及可以让它们合并以及拆分。

修改顺序其实很简单,我们只需要人为地修改 rebase -i 之后弹出的 vim 文件即可。比如说原本的记录是:

pick A change A
pick B change B
pick C change C

如果我们想要更换顺序,我们只需要修改这个文件即可。比如变成:

pick B change B
pick A change A
pick C change C

那么当我们在退出 vim 的时候,git 会首先应用 B commit 的变更,再应用 A 最后应用 C。

2、合并

除此之外,我们还可以合并多个 commit 记录成一个。操作的方法也很简单,就是我们只需要把 pick 修改成 squash。git 会自动把所有 squash 的 commit 记录合并在一起。

pick A change A
squash B change B
squash C change

3、拆分

有的时候一个 commit 非常巨大,我们可能也会想要将它拆分,其实操作也很简单。比如我们想要把 commit B 拆分成两条,首先,我们在 rebase 的时候将 commit B 前面的 pick 修改成 edit。

pick A change A
edit B change B
pick C change C

当我们退出的时候,我们会进入到 B commit 刚刚提交完的状态。由于我们要做的是拆分 B 这个提交,所以我们需要执行 git reset HEAD^,把上一次提交重置。然后再分别 add 我们想要拆分开来提交的文件。

整个操作如下:

git reset HEAD^
git add test/*
git ci -m 'add test'
git add code/*
git ci -m 'update code'
git rebase --continue

这样我们就把 commit B 拆分成了两个 commit 插入到了历史记录当中了。

最后的最后,大家需要注意,虽然这些手段在修改记录的时候非常好用。但是如果这些 commit 已经被提交到了远程,我们是不可以直接 git push 同步的。因为 git 会校验我们提交的 hash 值,发现对不上之后会禁止我们的提交。所以如果想要提交到远程的话,只能使用 git push -f 强制覆盖。但是这是一个非常非常危险的操作,如果你 git push -f 了,没有人会知道你到底修改了什么,只建议在自己独有的分支上如此操作,一定一定要谨慎使用。

福 利

CSDN旗下公众号全新搜索技能上线啦!

只要在公众号内回复消息

就能自动回复想搜索的内容啦!

现在体验有惊喜,每日参与搜索打卡,

连续打卡满3天、7天、14天

均有CSDN精美礼品相送 百分百有礼!快戳

每日体验CSDN公众号搜索功能打卡

更多精彩推荐
☞开源数据库再创里程碑,PingCAP 获 2.7 亿美元融资☞全球数百万台 Mac 疑似因 Big Sur 更新险酿计算灾难,苹果官方回应来了!
☞JavaScript 稳居第一、C# 连续下跌,调查 17000 名程序员后有了这些新发现!
☞中国第一代程序员潘爱民的 30 年程序人生
☞漫画:什么是 “千年虫” 问题?
☞万万没想到 Java 中最重要的关键字竟然是这个!
点分享点点赞点在看

Git提交错了不用慌,这三招帮你修改记录相关推荐

  1. Git 提交错了不用慌,这三招帮你修改记录

    作者 | 梁唐 来源 | TechFlow(ID:techflow2019) 头图 |  CSDN 下载自东方IC 大家好,今天我们来聊聊 git 当中一个很重要的功能--历史记录的修改. 有的时候我 ...

  2. cad里面f命令用不了,CAD出现命令无效、失灵等问题?不用慌,两招帮你快速解决...

    一.CAD常见无效问题 1.填充命令无效 我们有时候需要对某一区域进行填充,但是却发现怎么也填充不出来,这个时候就应该检查一下[选项]设置了,具体操作步骤如下: ①命令行中输入[OP],按下回车键调出 ...

  3. cad里面f命令用不了_CAD出现命令无效、失灵等问题?不用慌,两招帮你快速解决...

    一.CAD常见无效问题 1.填充命令无效 我们有时候需要对某一区域进行填充,但是却发现怎么也填充不出来,这个时候就应该检查一下[选项]设置了,具体操作步骤如下: ①命令行中输入[OP],按下回车键调出 ...

  4. 华为android系统通知栏怎么关闭,华为通知栏怎么设置?三招帮你禁止华为通知栏消息...

    原标题:华为通知栏怎么设置?三招帮你禁止华为通知栏消息 不管是华为.小米还是苹果三星等智能手机,都会有同一个困扰:每天都会接收到不少的推送栏消息,除了系统通知之外,还有各种各样的第三方应用推送消息,十 ...

  5. 网站被DDoS攻击怎么办?菜鸟站长之家教你这三招帮你防止、减轻DDoS攻击

    最近菜鸟站长之家遇到黑客的DDoS攻击来,导致域名www.cnzzzj.com资源被耗尽,服务.应用程序或网站崩溃,相信企业都对之深恶痛绝.今天给大家介绍一些有效的防止DDoS攻击的技术和方法,虽然很 ...

  6. 如何维持整洁的 Git 提交记录?送你三个锦囊!

    背景 大家都有学习如何规范简洁的编写代码,但却很少学习如何规范简洁的提交代码.现在大家基本上都用 Git 作为源码管理的工具,Git 提供了极大的灵活性,我们按照各种 workflow 来提交/合并 ...

  7. iphone照片删掉又出现_两个月前删的IPhone手机照片还有救?很简单,三招帮你轻松恢复...

    照片是我们记录生活的一种方法,而且现在手机的拍照功能也越来越强大了,大家不用再耗费高额的费用去买相机,特别是iPhone的拍照功能可以说是很出色了,所以拍照一直爽一直爽,如果手机里的照片手滑不删掉了怎 ...

  8. 索尼乐播投屏服务器未响应,乐播投屏电视没有声音怎么办?三招帮你解决令人困扰的问题!...

    软件大小: 37.43 MB 软件版本: 4.2.16.0 软件类型: 媒体其它 在我们平时的生活当中,周末宅在家里休息时,使用手机来追剧.看电影或者是看综艺,已经成为很多小伙伴周末宅在家里消磨时间的 ...

  9. 还说不会深度学习,三招帮你“炼丹”成功

    深度学习领域发展仍是火热朝天,众多方向门派百花齐放,CV和NLP领域一直是高手云集,Transformer最近异军突起,卷起一片波澜,其他众多领域,包括:迁移学习.强化学习.集成学习等,也有着各派的掌 ...

最新文章

  1. Python中的数据结构
  2. 彩图完美解释:麦克斯韦方程组
  3. DDoS攻防战(三):ip黑白名单防火墙frdev的原理与实现
  4. 使用easyexcel导出时行高不自动调整的解决
  5. 工作5年后我才发现:90%的技术问题,可以解决
  6. qt设置边框颜色_Qt开源作品14-导航按钮控件
  7. 深度学习2.0-27.动量与学习率衰减
  8. Word:不显示图片 + 清空“最近使用的文档”列表
  9. Luogu P1967 货车运输 倍增+最大生成树
  10. 【XLL 框架库函数】 TempMissing/TempMissing12
  11. Java处理Json数据
  12. Clickhouse分片集群性能测试
  13. websocket实现实时直播
  14. 维纳滤波python 函数_Wiener维纳滤波基本原理及其算法实现
  15. 在IGBT的开启过程中,IGBT的电压降低,电流上升,在IGBT的关断过程中IGBT的电压上升,电流下降,在一段时间内,电压和电流均不为0,由于功率等于电压乘以电流,即P=U×I,因此将产生损耗,开
  16. JNCIS-FWV Study Guide v1.3
  17. 适合协作办公的在线Word文档-超级文档
  18. 正则表达式匹配任意文本中的网络图片链接
  19. Ubuntu 14.04重装mysql
  20. 影视剧里程序员使用的双显示屏,在生活中真的需要么?正经科普

热门文章

  1. GCC全过程详解+剖析生成的.o文件[转]
  2. 525 Contiguous Array 连续数组
  3. Spring+springMvc+Mybatis
  4. gradle问题 cordova
  5. ubuntu14.04换一个更快的源
  6. 年报掘金:机构增仓路线图曝光(2010-03-06转载)
  7. 《Linux编程》学习笔记 ·002【Linux常用工具GCC、GDB、Make】
  8. [论文阅读] Shallow Attention Network for Polyp Segmentation
  9. 边缘计算(edge computing)中computation offloading、resource allocation、resource provisioning的区别
  10. 如何在矩池云GPU云中安装MATLAB 2019b软件