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

 

posted @ 2018-04-09 13:42  温柔的风  阅读(2461)  评论(0编辑  收藏  举报