• Git 回退代码的两种方法对比


    Git 回退代码版本

    在项目的开发中,有时候还是会出现,一些误提交了一些代码,这时候就会想撤回提交的代码,在Git中有两种方法可以使用,现在通过对比方法比较这两种方法的区别,分别适用于哪些情况?

    在Git中回退代码,经常使用revert或者reset来做,这两种操作都可以用来回退,但是却有比较大的区别,一般比较安全性的还是使用revert来做,revert是撤回对应的提交记录,然后再提交撤回记录,只是会在Git历史里多一些记录,reset的操作是直接将git历史回退到对应的版本,之后的记录全都撤回了,所以除非情况允许,不然不建议使用

    git revert操作

    git revert:revert撤回的意思,意思是撤回提交的代码,然后在Git的所有提交记录后面新增一次提交,不会撤回之前的代码,所以是很安全性的撤回方法,不过就会新增一次撤回记录

    git revert使用方法:

    # 撤回指定版本,后面可以加一个git记录id
    git revert [版本ID]
    # 撤回上个版本的提交
    git revert HEAD^
    # 撤回上上个版本提交
    git revert HEAD^^
    # 或者写成
    git revert HEAD^2
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    如果有git客户端软件,比如smartgit,可以直接在ui界面操作
    在这里插入图片描述

    然后再提交上去,重新生成一次撤回记录
    在这里插入图片描述

    git reset 操作

    git reset :reset,重置操作,是重置HEAD的位置,将代码重置到某个版本,某个版本之后的提交都会被清掉,所以不是很安全,非特殊情况,不建议使用

    git reset的语法格式为:

    git reset [--soft | --mixed | --hard] [HEAD]
    
    • 1
    • –mixed(默认):默认的参数,将重置的更改留在工作区中

    • –soft:如果使用 --soft 参数,将重置的更改保存在暂存区

    • –hard参数:如果使用 --hard 参数,工作区和暂存区都不会保存记录,所以建议不要使用这种模式

    OK,下面使用git命令实践一下

    # 找到要回退的commit版本号,复制
    git log 
    # 重置本地库版本回退
    git reset --mixed [commitid] 
    # 同步到远端仓库,要写上分支名称
    git push -f origin [branchName] 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    Linux 搭建NFS
    pytorch里常用操作(持续更新)
    王道数据结构6.2(图的应用)
    UCloud 对象存储使用
    如果你是独立开发者,你是先写前端还是先写后端?
    Qt5开发及实例V2.0-第一章Qt概述及Qt5的安装
    自媒体二号大前端主题模板 WordPress主题
    药品企业中的计算机系统验证管理规程
    Django如何配置Redis,以及如何使用
    Python 常用基础模块(四):sys模块
  • 原文地址:https://blog.csdn.net/u014427391/article/details/132807184