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

第一次提交,查看提交日志已经存在:
在这里插入图片描述
第二次add,然后提交修改
在这里插入图片描述

进入编辑界面,修改我们的提交信息
在这里插入图片描述
修改后

在这里插入图片描述

查看提交日志,只存在一次提交记录,信息也是显示的我们第二次提交的信息。

在这里插入图片描述

回退commit

git reset --soft // 回退到指定commit,该commit之后的提交内容,保留工作目录,并把重置 HEAD 所带来的新的差异放进暂存区
git reset --hard // 回退到指定commit,该commit之后的提交内容,工作区和暂存区的内容都被抹掉

git resetgit reset --mixed // 不带参数,或带参数–mixed(默认参数),与git reset --soft 不同,它将会把差异放到工作区
git reset --soft

首先我们先提交两次记录,这是第一次:
在这里插入图片描述

第二次:
在这里插入图片描述

查看提交HEAD
在这里插入图片描述

此时工作区没有任何修改未提交
在这里插入图片描述

git reset --soft HEAD^之后, 工作区有修改未提交,最后一次提交的内容暂存区保存了下来
在这里插入图片描述

提交记录以及不在,说明仓库中没有了这次提交
在这里插入图片描述

我们git status 发现上次提交的内容在暂存区,想要再次提交我们再继续commit就行

在这里插入图片描述

git reset --hard
首先我们提交,查看提交记录
在这里插入图片描述

git reset --hard 1134cb6回退到版本1134cb6(git reflog 可查询HEAD)
在这里插入图片描述

没有了txt文件,内容被彻底的删除了。
在这里插入图片描述

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

在这里插入图片描述

git reset HEAD || git reset --mixed
添加commit
在这里插入图片描述

回退,查看状态,前一次提交目前在工作区
在这里插入图片描述

小结

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

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐