Git实战技巧-如何撤销本地刚做出的修改、暂存和已提交
1、企业场景
今天刚上班,写了一个小时代码,发现需求理解不到位。代码要废弃掉,怎么办?
工作区内容怎么撤销?暂存内容怎么撤销?已经提交的怎么撤销?
2、解决方案
- 由于IDEA本身集成了Git功能,可以使用IDEA可视化界面解决。
- 可以使用Git命令解决。
3、动手实践
3.1、使用IDEA解决
撤销工作区内容
变更内容可以在Git工具窗口中直接撤销,如下图:
或者右键的文件,选择Git,然后选择Rollback也可以完成撤销。
撤销暂存区文件
IDEA中做代码更新后,可以不用额外的做暂存,直接提交就可以。所以可以不用考虑暂存撤销的问题。
已提交的撤销
IDEA中要撤销版本回到上一版本,或者回退到指定版本可以如下操作:
- 打开Git工具窗口,点击Log 查看版本提交记录。
- 然后右键你需要回退的版本,选择Rest Current Branch to Here。
- 此时会弹出一个菜单,供我们选择,选择需要的操作模式,然后点击Reset即可。
撤销模式说明:
四种模式在撤销回滚时,都会让HEAD指针改变指向到指定版本。
- Soft:回滚代码到指定版本时,工作区文件不会做改变,相较于指定版本多出的更新将会被暂存等待提交
- Mixed:回滚代码到指定版本时,工作区文件不会有改动,但是暂存会被清空
- Hard:回滚到指定版本时,工作区内容会回滚到指定版本,暂存也会被清空(慎重,未提交的代码有丢失风险)
- Keep:回滚到指定版本时,工作区内容会回滚到指定版本,暂存区未提交内容会保存
3.2、使用Git命令解决
工作区内容撤销
命令:git checkout–fileName
例如,对readme.txt 进行内容修改,保存文件。此时在Git Bash 中执行 git status
看效果。
上面有提示我们如何进行撤销,现在我们撤销readme.txt的修改:
已暂存撤销
命令:git reset HEAD file 移除暂存区回到工作区,内容在工作区中还是存在的
例如,对readme.txt 进行内容修改并已经暂存。现在需要撤销
此时在Git Bash 中执行 git status
看效果。
上面有提示我们如何进行撤销暂存,现在我们撤销readme.txt的暂存:
已提交撤销
当前知识点能够解决你在以后遇到的如下问题:
- 想要查看历史提交版本信息,
- 出于某些原因,想要将代码回撤重置到指定版本。
我们可以使用 git reset 命令来进行版本回退,而且可以指定退回到之前某一次提交的版本
命令:
git reset [--soft | --mixed | --hard --keep] [HEAD|版本号]
下面要完成以下操作:
1)重置到上一个版本 (当前提交撤销)
命令: git reset --hard HEAD^
HEAD参数说明:
git reset --hard HEAD
撤销暂存内容git reset --hard HEAD^
撤回到上一个版本git reset --hard HEAD^^
撤回到上上个版本- 以此类推
如果要回退到指定版本,建议用下面的方式。
2)重置指定版本
命令:
- 查看版本号命令
git reflog
- 按照版本号进行重置
git reset --hard 版本编号
4、企业规范建议
工作区和暂存区内容的撤销,直接按照对应命令或者IDEA界面完成操作就行。
对于已提交的撤销回滚建议如下:
- 代码如果仅仅是回撤到指定版本,该版本之上的更新是不需要的,选择Hard模式。
- 代码回撤到指定版本时,需要保存该版本之上的更新,可以选择Soft模式。
其他根据自己的需要选择即可。