git版本回退方式(git reset、git revert、git stash)

 更新时间:2025年04月07日 08:41:52   作者:Nyingchi-X  
这篇文章主要介绍了git版本回退方式(git reset、git revert、git stash),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

本文 git 相关命令

  • git reset: 回退版本,可指定某一次提交的版本。git reset [--soft | --mixed | --hard] commitId
  • git revert: 撤销某个提交,做反向操作,生成新的commitId,原有提交记录保留。git revert commitId
  • git commit --amend: git commit –amend既可以对上次提交的内容进行修改,也可以修改提交说明
  • git status: 查看文件在工作区和暂存区的状态。
  • git log: 查看代码提交记录,找到需要回滚的目标版本号。

回退的两种情况

修改README.md前

回退分两种情况:

1.已 commit,未push到远程仓库

修改README.md后

1.1 git reset --soft (撤销commit)修改了README.md,文档内容,并提交到了本地仓库

此时回滚README.md,通过 git reset --soft HEAD^ 回退上一个commit

注意: HEAD^的意思是上一个版本,也可以写成HEAD~1 ,如果你进行了2次commit,想都撤回,可以使用HEAD~2,这个命令仅仅是撤回commit操作,写的代码仍然保留1.2 git commit --amend(修改commit 提交的内容)

修改了README.md,文档内容,并提交到了本地仓库

输入 git commit --amend,利用vim语法,点击i进入编辑模式,修改对应文本内容,点击Esc退出编辑模式,按键:wq强制退出

1.3 git reset --mixed(撤销 commit 和 add 两个动作)

此时已经执行add和commit两个操作,git状态是这样的

输入git reset --mixed HEAD^ 撤销 commit 和 add 两个动作

2.已 commit,并且push到了远程仓库

2.1 git stash save “XXX”( 如果当前已修改了代码文件,发现需要进行版本回退,可以使用,将当前文件缓存)

输入git stash save "XXX"(能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录)

输入git stash pop/apply ,将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。

注:pop将堆栈中最近保存的内容删除(栈是先进后出),aplly不会删除保存的内容

可以使用git stash apply + stash名字(如stash@{1})指定恢复哪个stash到当前的工作目录。

git stash clear (清除堆栈中的所有 内容)

本文主要讲版本回退,相关缓存操作,请自行查找

2.2 git reset --hard 版本号(撤销并舍弃版本号之后的提交记录)

git log找到要回退到的版本号,当前第五次修改已缓存尚未提交,处于第四次提交的版本,此处要回退到第三次版本

输入git reset --hard be125c629a893e28f62439cf71b1e9671c73a4bb 回退到第三版本

此时README.md文档内容为

git push -f(强制推送到远程,之前提交都会被覆盖,慎用)

注: 通过reset的方式,此时可用看到提交记录和文件都被撤销了,reset之后,后面的版本就找不到了使用需谨慎,不推荐使用。

2.3 git revert 版本号(撤销,但是保留了提交记录)

git log找到要回退到的版本号,当前处于第四次提交的版本,此处要回退到第三版本

输入git revert -n be125c629a893e28f62439cf71b1e9671c73a4bb^..HEAD 回退到第三版本

提交文件,并查看日志

注: 这种方式不会把版本往前回退,而是生成一个新的版本。所以,你只需要让别人更新一下代码就可以了,你之前操作的提交记录也会被保留下来

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Matlab操作HDF5文件示例

    Matlab操作HDF5文件示例

    这篇文章主要为大家介绍了Matlab操作HDF5文件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Git的使用规范流程总结

    Git的使用规范流程总结

    大家都明白在团队开发中,遵循一个合理、清晰的Git使用流程,是非常重要的。否则,每个人都提交一堆杂乱无章的commit,项目很快就会变得难以协调和维护。所以这篇文章给大家分享了Git的使用规范流程,有需要的可以参考借鉴。
    2016-09-09
  • 算法系列15天速成 第一天 七大经典排序【上】

    算法系列15天速成 第一天 七大经典排序【上】

    今天是开篇,得要吹一下算法,算法就好比程序开发中的利剑,所到之处,刀起头落
    2013-11-11
  • Win10环境下 编译 和 运行 x264的详细过程

    Win10环境下 编译 和 运行 x264的详细过程

    这篇文章主要介绍了Win10环境下编译和运行x264的详细过程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • Git获取本地分支对应的远端服务器分支名的方法

    Git获取本地分支对应的远端服务器分支名的方法

    这篇文章主要介绍了Git获取本地分支对应的远端服务器分支名的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • HTTP请求 GET与POST方法的区别

    HTTP请求 GET与POST方法的区别

    HTTP定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST.HTTP-GET和HTTP-POST是使用HTTP的标准协议动词,用于编码和传送变量名/变量值对参数,并且使用相关的请求语义。
    2009-12-12
  • Node后端Express框架安装及应用

    Node后端Express框架安装及应用

    Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用和丰富的 HTTP 工具,如果你不会jJava or Python等后端,使用 Express可以帮助我们快速地搭建一个完整功能的网站
    2021-08-08
  • Hybris在idea中debug配置方法详解

    Hybris在idea中debug配置方法详解

    这篇文章主要介绍了Hybris在idea中debug配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • 详解git使用小结(本地分支与远程分支、git命令)

    详解git使用小结(本地分支与远程分支、git命令)

    这篇文章主要介绍了git使用小结(本地分支与远程分支、git命令),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Jenkins集成Gitlab实现自动化部署的全过程记录

    Jenkins集成Gitlab实现自动化部署的全过程记录

    因为中型公司不可能配置运维开发,而开发只管开发的,所以运维只能是通过使用开源工具的方式来搭建自动化部署系统,下面这篇文章主要给大家介绍了关于Jenkins集成Gitlab实现自动化部署的相关资料,需要的朋友可以参考下
    2022-04-04

最新评论