一、使用reset命令撤销本地仓库的提交
1.我在README文件中,写一点东西,然后提交;
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ vim README
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git commit -m '写README文件'
[master efb939b] 写README文件
1 file changed, 10 insertions(+)
2.然后,我觉得我写的不正确,但是我已经提交到本地仓库了,如果我想要撤销上一次的提交,我可以进行reset操作(注意--soft表示使用比较柔和的方式,HEAD~1表示最近一次的提交);然后执行完,查看git status,就可以看到git的当前状态,可以看到README文件回到了待提交列表中;
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git reset --soft HEAD~1
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
modified: README
如果,我使用git reset HEAD~1,不使用柔和的方式撤销,就会直接将上一次提交到本地仓库的文件回退到本地代码中;
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git reset HEAD~1
Unstaged changes after reset:
M README
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: README
但是,注意:
撤销操作不要轻易使用,一般用的很少,因为协同开发,使用撤销可能会出现严重问题!
二、使用checkout撤销本地还未提交的改动
1.接着前面的操作,我们已经将之前修改的README文件已经回退到了本地代码中,并且告知我们README文件已经做了修改,提示我们:(1)使用git add 将该文件添加到待提交列表中;(2)使用git checkout来取消该文件的改动;
我们使用git checkout -- README 命令来取消修改,然后使用git diff看看修改前后的不同之处,因为我们是在空白的文件中添加,然后又取消了,所以现在没有什么不同,然后使用git status查看状态,可以看到没有需要提交的,我们已经成功回退到原来的版本,再查看README文件,里面依旧是空白的,跟修改前是一样的;
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git checkout -- README
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git diff
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ git status
On branch master
nothing to commit, working tree clean
aibin@XiaoAibin MINGW64 ~/Desktop/test_git (master)
$ vim README
本文为原创文章,如果对你有一点点的帮助,别忘了点赞哦!比心!如需转载,请注明出处,谢谢!