git commit 回退

弄清楚三个区

  • 工作区(working tree): 本地编辑器
  • 暂存区(index):git add操作后进入暂存区,可用git status查看
  • 本地仓库(repository):git commit 后进入本地仓库

修改commit

当我们第一次提交后,发现还有修改没有提交,通常我们想的是在add/commit一次,这样存在的问题呢就是会有一些扰乱我们的commit信息。比如我们第二次commit提交信息可能是“删除上次提交的debugger”
其实我们两次提交内容的目的都是同一个,比如修改bug,第一次提交时忘了删除我们调试时留下的debugger。然后就删除提交第二次,第二次的提示信息就很不友好。我们怎么来将两个commit合为一个呢?

  • git commit --amend // 把上一次的commit记录去除,修改commit信息。

git commit --amend

第一次提交,查看提交日志已经存在:
git commit回退三种姿势
第二次add,然后提交修改
git commit回退三种姿势
进入编辑界面,修改我们的提交信息
git commit回退三种姿势
修改后
git commit回退三种姿势
查看提交日志,只存在一次提交记录,信息也是显示的我们第二次提交的信息。
git commit回退三种姿势

回退commit

  • git reset --soft // 回退到指定commit,该commit之后的提交内容,保留工作目录,并把重置 HEAD 所带来的新的差异放进暂存区
  • git reset --hard // 回退到指定commit,该commit之后的提交内容,工作区和暂存区的内容都被抹掉
  • git reset 或 git reset --mixed // 不带参数,或带参数–mixed(默认参数),与git reset --soft 不同,它将会把差异放到工作区

git reset --soft

首先我们先提交两次记录,这是第一次:
git commit回退三种姿势
第二次:
git commit回退三种姿势
查看提交HEAD
git commit回退三种姿势
此时工作区没有任何修改未提交
git commit回退三种姿势
git reset --soft HEAD^之后, 工作区有修改未提交,最后一次提交的内容暂存区保存了下来
git commit回退三种姿势
提交记录以及不在,说明仓库中没有了这次提交
git commit回退三种姿势
我们git status 发现上次提交的内容在暂存区,想要再次提交我们再继续commit就行
git commit回退三种姿势

git reset --hard

首先我们提交,查看提交记录
git commit回退三种姿势
git reset --hard 1134cb6回退到版本1134cb6(git reflog 可查询HEAD)
git commit回退三种姿势
没有了txt文件,内容被彻底的删除了。
git commit回退三种姿势

也没有了提交记录,工作区也没有代码。这时候工作区,暂存区和仓库都是一样的回退到了指定commit
git commit回退三种姿势

git reset HEAD || git reset --mixed

添加commit
git commit回退三种姿势
回退,查看状态,前一次提交目前在工作区
git commit回退三种姿势

小结

  • git commit --amend 好用,减少提交无用信息,可常用。
  • git reset --soft HEAD 回退,差异存在暂存区,也好用,不轻易删除代码。
  • git reset --hard HEAD 回退删除, 慎用,一不小心删除代码还不可逆。
  • git reset HEAD || git reset --mixed HEAD 回退,改变的差异在工作区。

相关文章: