zoukankan      html  css  js  c++  java
  • Git撤销操作

     
     
    ——撤销已经修改,但是还没有添加到暂存区的操作:
    解决方案:
    有两种情形:
    第一种情形:如果一个文件是新建的文件,没有untrack,说明这个文件在库里就没有版本,所以用git rm 命令是匹配不到的。所以这种文件是没有跟踪版本的,也就不能知道,到底修改了什么。如果要跟踪,就要add到tracking文件列表当中;
    这种文件自然就没有撤销之说了,如果不想要了,就只能直接执行删除操作:
    # 删除 untracked files
    git clean -f
     
    # 连 untracked 的目录也一起删掉
    git clean -fd
     
    # 连 gitignore 的untrack 文件/目录也一起删掉 (慎用,一般这个是用来删掉编译出来的 .o之类的文件用的)
    git clean -xfd
     
    # 在用上述 git clean 前,墙裂建议加上 -n 参数来先看看会删掉哪些文件,防止重要文件被误删
    git clean -nxfd
    git clean -nf
    git 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 来跳转
    # 回退到特定版本777b7eb
    git reset --hard 777b7eb
    解决方案二:
    使用git revert commit_id 进行还原
    # 还原到上一个版本
    git revert HEAD
    # 还原到某个特定的版本
    git revert commit_id
     
    注意:以上两个方案的区别是,revert会生成一个新的commit版本,同时生成一个commit_id;而reset不会生成新的commit,只会生成一个监控的commit_id





  • 相关阅读:
    [UVA10859 放置街灯 Placing Lampposts]
    洛谷7月月赛题解(2020)
    [学习笔记]马拉车-Manacher
    [SP1026] FAVDICE
    [NOIP2013]货车运输
    [洛谷P1801]黑匣子
    [HAOI2015]树上染色
    python-第二块:time模块和datatime模块
    python-作业:员工信息表
    python-第二块,笔记整理和学习内容复习(day7)
  • 原文地址:https://www.cnblogs.com/Zhanxueyou/p/5128241.html
Copyright © 2011-2022 走看看