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


    1、解决思路

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

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

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

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

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

    2、动手实践

    2.1、基于IDEA解决

    1)撤销工作区内容

    变更内容可以在Git工具窗口中直接撤销,如下图:在这里插入图片描述
    或者右键的文件,选择Git,然后选择Rollback也可以完成撤销。

    在这里插入图片描述

    2)撤销暂存区文件

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

    3)已提交的撤销

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

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

    在这里插入图片描述

    1. 然后右键你需要回退的版本,选择Rest Current Branch to Here
      在这里插入图片描述

    2. 此时会弹出一个菜单,供我们选择,选择需要的操作模式,然后点击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的暂存:
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MctZ3sMB-1655865522096)(imgs/1652423060334-454a5159-ad38-4ec5-982c-5b9f7a91eb81.png)]

    3)已提交撤销

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

    1. 想要查看历史提交版本信息
    2. 出于某些原因,想要将代码回撤重置到指定版本

    我们可以使用 git reset 命令来进行版本回退,而且可以指定退回到之前某一次提交的版本

    命令:

    git reset [--soft | --mixed | --hard --keep] [HEAD|版本号]
    
    • 1

    下面要完成以下操作:

    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 版本编号

  • 相关阅读:
    tomcat读取文件路径问题
    企业与企业之间保密协议
    什么是供应商管理?供应商管理办法及流程介绍
    如何做好自动化测试?揭开测试项目团队的自动化实践过程……
    Nerf三维重建Pytorch使用Pycharm运行0基础教程
    STlink下载出现st-link usb communication error解决方法
    本周Github有趣的项目、工具和库:Radius等
    docker安装redis并搭建集群
    为什么OpenAPI是未来企业数字化转型的决定性因素
    【教程】 iOS混淆加固原理篇
  • 原文地址:https://blog.csdn.net/cz_00001/article/details/125404904