备忘录——关于Git的撤销和还原
-
Git恢复之前版本的两种方法reset、revert(图文详解
- 该文中的示意图完整的展示了两个命令的含义
-
撤销(Reset)
- 如果想恢复到之前某个提交的版本,且那个版本之后提交的版本我们都不要了(是指远程的那些之后版本不要了,那些修改可以Mixed参数保留在本地)
- 撤销模式说明: 四种模式在撤销回滚时,都会让HEAD指针改变指向到指定版本。
- Soft:回滚代码到指定版本时,工作区文件不会做改变,相较于指定版本多出的更新将会被暂存等待提交
- Mixed:回滚代码到指定版本时,工作区文件不会有改动,但是暂存会被清空
- Hard:回滚到指定版本时,工作区内容会回滚到指定版本,暂存也会被清空(慎重,未提交的代码有丢失风险)
- Keep:回滚到指定版本时,工作区内容会回滚到指定版本,暂存区未提交内容会保存
- 撤销模式说明: 四种模式在撤销回滚时,都会让HEAD指针改变指向到指定版本。
- 如果想恢复到之前某个提交的版本,且那个版本之后提交的版本我们都不要了(是指远程的那些之后版本不要了,那些修改可以Mixed参数保留在本地)
-
还原(revert)
- 如果我们想撤销之前的某一版本,但是又想保留该目标版本后面的版本
-
提交到本地仓库(commit)而没有推送到远程,想要撤销该提交,则选中上一个远程提交的版本后执行:Reset -Mixed