Git撤销操作
——撤销已经修改,但是还没有添加到暂存区的操作:

解决方案:
有两种情形:
第一种情形:如果一个文件是新建的文件,没有untrack,说明这个文件在库里就没有版本,所以用git rm 命令是匹配不到的。所以这种文件是没有跟踪版本的,也就不能知道,到底修改了什么。如果要跟踪,就要add到tracking文件列表当中;
这种文件自然就没有撤销之说了,如果不想要了,就只能直接执行删除操作:
# 删除 untracked filesgit clean -f# 连 untracked 的目录也一起删掉git clean -fd# 连 gitignore 的untrack 文件/目录也一起删掉 (慎用,一般这个是用来删掉编译出来的 .o之类的文件用的)git clean -xfd# 在用上述 git clean 前,墙裂建议加上 -n 参数来先看看会删掉哪些文件,防止重要文件被误删git clean -nxfdgit clean -nfgit clean -nfd第二种情形:如果一个文件已经在版本库中,要撤销对这个文件未暂存的修改,可以使用git checkout 来更新文件来撤销更改:
git checkout filename——撤销已经添加到暂存区域的修改
解决方案1:
分两步:第一步将文件从暂存区移除:
git reset HEAD filename第二步:放弃对文件的修改:
git checkout filename——撤销已经提交到版本库的修改:
解决方案:
在git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上个版本就是HEAD^^,要是上一百个版本,就可以写成HEAD~100
# 回退到上一个版本git reset --hard HEAD^# 回退到上上个版本git reset --hard HEAD^^# 回退到上100个版本git reset --hard HEAD~100如果要回退或前进到某个特定版本,需要借助git reflog查看所有commit_id,然后git reset --hard HEAD commit_id 来跳转

# 回退到特定版本777b7ebgit reset --hard 777b7eb解决方案二:
使用git revert commit_id 进行还原
# 还原到上一个版本git revert HEAD# 还原到某个特定的版本git revert commit_id注意:以上两个方案的区别是,revert会生成一个新的commit版本,同时生成一个commit_id;而reset不会生成新的commit,只会生成一个监控的commit_id

浙公网安备 33010602011771号