git实战技巧-本地刚做出的修改、暂存和提交如何进行撤销

 1、解决思路

  工作区和暂存区内容的撤销,直接按照对应命令或者IDEA界面完成操作就行。

  对于已提交的撤销回滚建议如下:

  1. 代码如果仅仅是回撤到指定版本,该版本之上的更新是不需要的,选择Hard模式。

  2. 代码回撤到指定版本时,需要保存该版本之上的更新,可以选择Soft模式。

  其他根据自己的需要选择即可。

  2、动手实践

  2.1、基于IDEA解决

  1)撤销工作区内容

  变更内容可以在Git工具窗口中直接撤销,如下图:

  或者右键的文件,选择Git,然后选择Rollback也可以完成撤销。

  2)撤销暂存区文件

  IDEA中做代码更新后,可以不用额外的做暂存,直接提交就行了。所以可以不用考虑暂存撤销的问题。

  3)已提交的撤销

  IDEA中要撤销版本回到上一版本,或者回退到指定版本可以如下操作:

  1. 打开Git工具窗口,点击Log 查看版本提交记录

  

2. 然后右键你需要回退的版本,选择Rest Current Branch to Here

  

3. 此时会弹出一个菜单,供我们选择,选择需要的操作模式,然后点击Reset即可

  

撤销模式说明:

  四种模式在撤销回滚时,都会让HEAD指针改变指向到指定版本。

  1. Soft:回滚代码到指定版本时,工作区文件不会做改变,相较于指定版本多出的更新将会被暂存等待提交

  2. Mixed:回滚代码到指定版本时,工作区文件不会有改动,但是暂存会被清空

  3. Hard:回滚到指定版本时,工作区内容会回滚到指定版本,暂存也会被清空(慎重,未提交的代码有丢失风险)

  4. Keep:回滚到指定版本时,工作区内容会回滚到指定版本,暂存区未提交内容会保存

  2.2、基于Git命令解决

  1)工作区内容撤销

  命令:`git checkout -- fileName`

  例如,对readme.txt 进行内容修改,保存文件。此时在Git Bash 中执行 `git status`看效果。

  上面有提示我们如何进行撤销,现在我们撤销readme.txt的修改:

  2)已暂存撤销

  命令:

  `git reset HEAD file` 移除暂存区回到工作区,内容在工作区中还是存在的

  例如,对readme.txt 进行内容修改并已经暂存。现在需要撤销

  此时在Git Bash 中执行 `git status`看效果。

  上面有提示我们如何进行撤销暂存,现在我们撤销readme.txt的暂存:

  3)已提交撤销

  当前知识点能够解决你在以后遇到的如下问题,

  1. 想要查看历史提交版本信息

  2. 出于某些原因,想要将代码回撤重置到指定版本

  我们可以使用 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)重置指定版本

  命令:

  1. 查看版本号命令

  `git reflog`

  2. 按照版本号进行重置

  `git reset --hard 版本编号`

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值