记一次git硬reset导致的代码消失

    最近项目比较敢,心情烦躁,想取消一个commit,于是不知咋地鬼使神差地reset current brand to here,就这样

  

    还点了hard

    然后,辛苦写的代码就这样没有了...

 

    


    此次反映出自己对checkout,revert,reset 不熟悉.

    补习一下.

  • git resetgit checkout 和 git revert 是你的 Git 工具箱中最有用的一些命令。它们都用来撤销代码仓库中的某些更改,而前两个命令不仅可以作用于提交,还可以作用于特定文件。
  • Git 仓库有三个主要组成——工作目录,缓存区和提交历史。
  • 你传给 git reset 和 git checkout 的参数决定了它们的作用域。如果你没有包含文件路径,这些操作对所有提交生效。
    •   git checkout [branch/commit]
  • reset 参数
      • --soft – 缓存区和工作目录都不会被改变
      • --mixed – 默认选项。缓存区和你指定的提交同步,但工作目录不受影响
      • --hard – 缓存区和工作目录都同步到你指定的提交
  •   Revert
    •   Revert 撤销一个提交的同时会创建一个新的提交。这是一个安全的方法,因为它不会重写提交历史。

猜你喜欢

转载自www.cnblogs.com/imjamin/p/9998833.html