场景描述
假设你创建了一个文件,并写入了一些内容,然后通过git add
和git commit
将此变更提交。提交之后才发现这个文件中少了一些内容,此时有两个选择摆在你面前:
-
将文件内容补全,然后和之前一样
git add
、git 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记录同样只会有一条。
网友评论