git撤销提交
1、 git commit之后,想撤销commit
写完代码后,我们一般这样
#git add . //添加所有文件
#git commit -m "本功能全部完成"
执行完commit后,发现写的东西有问题,想撤销这次提交,怎么办?
可以执行下面操作:
#git reset --soft HEAD~1
这样就撤销了刚刚提交,但是代码依然还在工作空间保留。HEAD~1代表最近一次提交,HEAD~N代表最近n次提交
现在我对上面命令进行解释,
#git-reset - Reset current HEAD to the specified state
git reset命令有三种工作模式:
soft:只是将head重置
mixed:只是将head和缓存重置
hard:把head、缓存、工作空间重置
具体的使用方法见下图:
要理解这三种模式之前,需要了解git的基本流程。
正如上图所示,git在本地有三个工作区域:
working directory:工作目录
Stage/Index:缓存区域
Repository:本地仓库,用于存储历史提交
1、 刚开始工作空间、缓存、仓库里面的内容是一致的
2、 当我们对工作空间的内容进行了修改,这时工作空间的内容就和缓存、本地仓库的不一样了,git自动追踪修改后的文件,将状态设置为modified(unstaged files)
3、 当我们通过git add命令将这些修改的文件提交到缓存,这时工作空间和缓存的内容一致,但是与本地仓库不一致,git将这些修改的文件,它们的状态设置为staged files,
4、 接着执行git commit,将缓存中的内容提交到本地仓库,建立新的commit节点