Git撤销add、commit、merge、所有修改文件
撤销add
git status 查看当下更新的文件
git reset HEAD 表示撤销上次add的所有文件
git reset HEAD dir/dir/test.php 撤销指定文件 或者 git reset HEAD --- filename1 filename2
撤销commit
在项目开发过程中,完成某项功能的时候需要执行以下命令
git add . 添加所有文件
git commit -m "finish"
有时候在执行完commit,想撤回去再次修改可以执行以下命令
git reset --soft HEAD^ //这样就成功的撤销了你上次的commit(仅仅是撤回commit操作,代码仍然保留)
PS:
HEAD^的意思是上一个版本,也可以写成HEAD~1
如果你进行了2次commit,想都撤回,可以使用HEAD~2
HELP:
--mixed
意思是:不删除工作空间改动代码,撤销commit,并且撤销git add . 操作
这个为默认参数,git reset --mixed HEAD^ 和 git reset HEAD^ 效果是一样的。
--soft
不删除工作空间改动代码,撤销commit,不撤销git add .
--hard
删除工作空间改动代码,撤销commit,撤销git add .
注意完成这个操作后,就恢复到了上一次的commit状态。
如果commit注释写错了,只是想改一下注释,只需要:
git commit --amend //此时会进入默认vim编辑器,修改注释完毕后保存就好了。
想要工作区跟暂存区一样,记得用git checkout 文件名
想要变更暂存区的内容 ,记得用git reset命令
撤销merge
git reset --hard HEAD
撤销所有修改文件
git checkout . && git clean -xdf