最近项目比较敢,心情烦躁,想取消一个commit,于是不知咋地鬼使神差地reset current brand to here,就这样
还点了hard
然后,辛苦写的代码就这样没有了...
此次反映出自己对checkout,revert,reset 不熟悉.
补习一下.
git reset
、git checkout
和git revert
是你的 Git 工具箱中最有用的一些命令。它们都用来撤销代码仓库中的某些更改,而前两个命令不仅可以作用于提交,还可以作用于特定文件。- Git 仓库有三个主要组成——工作目录,缓存区和提交历史。
- 你传给
git reset
和git checkout
的参数决定了它们的作用域。如果你没有包含文件路径,这些操作对所有提交生效。
- git checkout [branch/commit]
- reset 参数
-
- --soft – 缓存区和工作目录都不会被改变
- --mixed – 默认选项。缓存区和你指定的提交同步,但工作目录不受影响
- --hard – 缓存区和工作目录都同步到你指定的提交
-
- Revert
- Revert 撤销一个提交的同时会创建一个新的提交。这是一个安全的方法,因为它不会重写提交历史。