撤销修改

GIT 撤销修改,主要利用 git restore 命令。现在,我们来假象一个使用场景。当我们大半夜战至性头时,一上头不小心在文件中写了句不该写的话"老板是个大煞笔"!并且已经 git add 到暂存区(staged) 中了!如果再继续commit 的话,第二天就面临失业的风险!

在这里插入图片描述

$ git status
On branch master
Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
        modified:   READEME.md

从上面可以看到,有一个待提交文件,并且还有一个重要的提示:use “git restore --staged …” to unstage ,翻译过来就是,使用 git restore --staged … 可以使文件变成已修改(未执行 add 时 )状态。
好的,是时候展现真正的技术了,命令敲起来ヾ(゚∀゚ゞ):

$ git restore --staged READEME.md
$ git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
        modified:   READEME.md

当我们执行 store --staged 命令后,再用 status 查看状态,会发现,文件已经变成 add 执行前的状态了。是的,这样咱们就彻底保住了工作。现在划重点,我们看下执行 git restore --staged READEME.md 到底发生了什么。

  • git restore --staged [file] : 表示从暂存区将文件的状态修改成 unstage 状态。
  • 当然,也可以不指定确切的文件 ,例如: git restore --staged *.java 表示将所有暂存区的java文件恢复状态
  • git restore --staged . 表示将当前目录所有暂存区文件恢复状态
  • –staged 数就是表示仅仅恢复暂存区的

可以看到,我我们又有错别字了,但是已经 commit 了,那么应该怎么办呢?

$ git restore -s HEAD~1 READEME.md  // 该命名表示将版本回退到当前快照的前一个版本
$ git restore -s 91410eb9  READEME.md  // 改命令指定明确的 commit id ,回退到指定的快照中
$ git reset --soft HEAD^  // 该命令表示撤销 commit 至上一次 commit 的版本

总结
本篇文章的所有重点都集中在一个命令上 restore ,该命令主要有三个参数,我重点介绍一下,restore 命令,默认是带着 --worktree 参数的

在这里插入图片描述

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐