git --- 回滚 restore, reset, revert

git --- 回滚 restore, reset, revert

  • git revert
  • git restore
  • git reset
    • git reset --soft
    • git reset --mixed
    • git reset -- hard

git revert

  • git revert 是用于“反做”某一个版本,以达到撤销该版本的修改的目的
  • 也就是git revert会生成一个新的commit, 而这个commit需要回滚的版本的内容是一样的
  • 如下, 比如版本三的commit有问题, 需要进行版本回退, 则执行 git revert 版本二 这个命令, git会生成版本四, 而版本四的内容和版本二是一样的
    git --- 回滚 restore, reset, revert_第1张图片

Example

  • 目前有一个greeting.txt文件, git 记录如图
    git --- 回滚 restore, reset, revert_第2张图片
  • 使用revert 恢复到最近一个commit之前的样子(commit 0343dc3)
    在这里插入图片描述
  • 查看git 记录以及greeting.txt的内容
    git --- 回滚 restore, reset, revert_第3张图片
  • 注意: 如果要恢复到几个版本以前的状态, 尽量一个一个恢复, 避免冲突
  • 比如要恢复到 fbc9245 之前的状态, 则先revert 020cf2e --> revert 0343dc3 --> reevrt 2d73d74 ----> revert fbc9245

git restore

  • git restore有两种用法
  • 如果文件在工作区, 还没有被add进缓存区, 则git restore会直接丢弃目前工作区的更改
  • 如果文件在缓存区, 则需要使用 git restore --staged 将文件从缓存区移动回工作区

Example

git restore -- staged
  • 现在有一个更改, 已经被加入进缓存区
  • 使用 git restore --staged bar.txt 将文件移出缓存区, 放进工作区

git --- 回滚 restore, reset, revert_第4张图片

git restore
  • 使用 git restore 将工作区的代码丢弃, 恢复原状
    git --- 回滚 restore, reset, revert_第5张图片

Example: 恢复被删除的文件
git --- 回滚 restore, reset, revert_第6张图片

git reset

git reset --soft

  • 仅仅移动当前 Head 指针,不会改变工作区和暂存区的内容
  • 之前commit的内容, 包括新增的文件,会被放进暂存区 (未commit)

Example:

  • 现在工作区 有一个修改, 暂存区有一个修改
    git --- 回滚 restore, reset, revert_第7张图片
  • git 记录如下
    git --- 回滚 restore, reset, revert_第8张图片
  • 执行 git reset --soft HEAD~1 表示恢复到HEAD指针上一个版本
  • 暂存区和工作区的文件不会被改动, 仅仅是HEAD指针被移动了 而之前的commit (新加10.txt) 全部会被放进缓存区
    git --- 回滚 restore, reset, revert_第9张图片
    git --- 回滚 restore, reset, revert_第10张图片
  • 注意此时的commit 10不会被丢弃,依然存在
    git --- 回滚 restore, reset, revert_第11张图片
  • 如果在工作区或者缓存区的文件就是上次修改的文件,则会合并内容
  • 10.txt 从modified变为 new file,但是内容没有被丢弃
    git --- 回滚 restore, reset, revert_第12张图片
    在这里插入图片描述

git reset --mixed

  • 移动当前 Head 指针
  • 之前commit的内容会被放进工作区
  • 目前缓存区的内容也会被放进工作区
  • 新增的文件会变为untracked状态(也就是放进工作区)

Example

  • 下面是mixed reset之前的状态
    git --- 回滚 restore, reset, revert_第13张图片
  • 执行 git reset --mixed HEAD~1
  • 原来在缓存区的 1.txt会被放进工作区,而原来的新文件10.txt会被变为untracked状态(放进工作区)
  • 之前的commit内容 新文件 9.txt 也被直接变为untracked状态 (放进工作区)

git --- 回滚 restore, reset, revert_第14张图片

git reset – hard

  • 将暂存区与工作区都回到上一次版本,并删除之前的所有信息提交,当前 HEAD 指针、工作区和暂存区内容全部改变
  • 原有文件内容的变更 :修改内容丢失(修改的代码不会变成未add的状态)
  • 目录结构的变更(增加或者删除文件):新增文件丢失、删除的文件相当于没删

Example

  • 下面是hard reset之前的状态
    git --- 回滚 restore, reset, revert_第15张图片
  • 执行 git reset --hard HEAD~1 之后,工作区和暂存区全部被清空,回到上一个commit
    git --- 回滚 restore, reset, revert_第16张图片
  • 注意, commit 10不会被删除,依然存在
    git --- 回滚 restore, reset, revert_第17张图片

你可能感兴趣的:(git,git)