利用`git commit —amend —no-edit`命令修改上一次变更内容

场景描述

假设你创建了一个文件,并写入了一些内容,然后通过git addgit commit将此变更提交。提交之后才发现这个文件中少了一些内容,此时有两个选择摆在你面前:

  • 将文件内容补全,然后和之前一样git addgit commit。显然,你可以通过git log看到这两条commit记录。

  • 回到过去,修改上一次提交的那个文件。如此一来,你的commit记录只会有一条。对于一些有代码洁癖并且看中git commit记录的程序员,这点很重要,特别是在开源项目中。

场景再现

  • 初始化git仓库
$ mkdir test && cd test && git init
  • 第一次commit内容
$ echo 'Hello world' > README.md
$ git add .
$ git commit -m "Add README.md"
$ git log --oneline
c56f680 Add README.md
  • 修改文件内容并合并到上一次的commit变更当中
$ echo 'Hello voidint' >> README.md
$ git add .
$ git commit --amend --no-edit
$ git log --oneline
eb6c8cb Add README.md // hash值发生了变化

可以看到,在执行git commit --amend --no-edit之后,hash值由c56f680变成了eb6c8cb,但是message内容并没有发生变化,并且最重要的是只有一条commit记录。

如果要修改上一条的message,那么去掉--no-edit选项即可,git commit --amend -m "xxxx"。同理,commit记录同样只会有一条。

你可能感兴趣的:(利用`git commit —amend —no-edit`命令修改上一次变更内容)