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 reset 或 git 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 回退,改变的差异在工作区。