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

这篇具有很好参考价值的文章主要介绍了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到远程仓库。

git版本回退(git reset、git revert、git stash)
修改README.md后

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

1.1 git reset --soft (撤销commit)
  • 修改了README.md,文档内容,并提交到了本地仓库
    git版本回退(git reset、git revert、git stash)
  • 此时回滚README.md,通过 git reset --soft HEAD^ 回退上一个commit
    git版本回退(git reset、git revert、git stash)
    注意: HEAD^的意思是上一个版本,也可以写成HEAD~1 ,如果你进行了2次commit,想都撤回,可以使用HEAD~2,这个命令仅仅是撤回commit操作,写的代码仍然保留
1.2 git commit --amend(修改commit 提交的内容)
  • 修改了README.md,文档内容,并提交到了本地仓库
    git版本回退(git reset、git revert、git stash)

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

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

1.3 git reset --mixed(撤销 commit 和 add 两个动作)
  • 此时已经执行add和commit两个操作,git状态是这样的

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

  • 输入git reset --mixed HEAD^ 撤销 commit 和 add 两个动作
    git版本回退(git reset、git revert、git stash)

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

2.1 git stash save “XXX”( 如果当前已修改了代码文件,发现需要进行版本回退,可以使用,将当前文件缓存)
  • 输入git stash save "XXX"(能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录)
    git版本回退(git reset、git revert、git stash)

  • 输入git stash pop/apply ,将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
    注:pop将堆栈中最近保存的内容删除(栈是先进后出),aplly不会删除保存的内容
    git版本回退(git reset、git revert、git stash)
    git版本回退(git reset、git revert、git stash)
    可以使用git stash apply + stash名字(如stash@{1})指定恢复哪个stash到当前的工作目录。

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

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

2.2 git reset --hard 版本号(撤销并舍弃版本号之后的提交记录)
  • git log找到要回退到的版本号,当前第五次修改已缓存尚未提交,处于第四次提交的版本,此处要回退到第三次版本
    git版本回退(git reset、git revert、git stash)

  • 输入git reset --hard be125c629a893e28f62439cf71b1e9671c73a4bb 回退到第三版本
    git版本回退(git reset、git revert、git stash)
    此时README.md文档内容为
    git版本回退(git reset、git revert、git stash)

  • git push -f(强制推送到远程,之前提交都会被覆盖,慎用)
    git版本回退(git reset、git revert、git stash)
    注: 通过reset的方式,此时可用看到提交记录和文件都被撤销了,reset之后,后面的版本就找不到了使用需谨慎,不推荐使用。

2.3 git revert 版本号(撤销,但是保留了提交记录)
  • git log找到要回退到的版本号,当前处于第四次提交的版本,此处要回退到第三版本
    git版本回退(git reset、git revert、git stash)

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

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

  • 提交文件,并查看日志
    git版本回退(git reset、git revert、git stash)
    git版本回退(git reset、git revert、git stash)
    注: 这种方式不会把版本往前回退,而是生成一个新的版本。所以,你只需要让别人更新一下代码就可以了,你之前操作的提交记录也会被保留下来文章来源地址https://www.toymoban.com/news/detail-478093.html

到了这里,关于git版本回退(git reset、git revert、git stash)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Git 基础知识--stash 存储、reset 回退及恢复

    简介 Git 提供了 stash 存储的功能,即当你在工作到一半突然需要切换到另一个分支上,但又不想提交时,可将当前做出的修改通过 git stash 命令存储起来,之后再从其中重新读取之前的状态。 注意事项 若修改的文件没有执行 git add 即未被跟踪,则该文件不会被 git stash 存储,

    2023年04月10日
    浏览(39)
  • git reset 命令详解 git revert命令详解。

    git reset 命令格式为: git reset [ --soft | --mixed | --hard ] [ commitid ] 在git的这些命令中git reset是最长常用的,也是最危险的最容易被误用的。它的主要参数是:soft,mixed,hard它们告诉git,当执行reset是,要对index和working copy做什么。 soft: –soft参数只将其它的commit重置到你选定的HEAD,

    2024年02月15日
    浏览(44)
  • 使用git reset回退版本

    在介绍版本回退之前先介绍下如何git log命令,可以查看我们的提交历史记录。 先看下我的提交记录 最新的提交中,我在main.cpp中添加了这两行代码  此时,我们就可以使用 git reset --hard 命令进行版本回退 git reset --hard 后面跟你要回退的那个版本的commit值,我们回退到 \\\"配置文

    2024年02月09日
    浏览(33)
  • git reset 版本回退或撤销上一次pull操作

    在拉取分支准备合并的时候,发现分支拉错了,不想提交,这时候你应该回退一下你所拉取的分支 比如我现在已经执行完git pull 了,但是想回头git pull之前的内容 upstream 是我远程分支 pro是我远程分支的生产环境 现在我们先看看历史提交记录 git reflog 打印的更为详细一些 这里

    2024年02月11日
    浏览(38)
  • git reset回退版本【Git异常】You are in ‘detached HEAD‘ state

    git clone项目后,在main分支回退版本,出现报错 detached HEAD称为分支游离状态 1、从远程库clone下来一个远程的repository; 2、clone下来之后,git自动在本地建立了一个本地分支master,并自动与远程库master关联; 3、现在在操作checkout其他分支名(dev_v1);因为本地的工作区目前是刚刚

    2024年02月11日
    浏览(41)
  • Git基础操作:git stash 相关命令举例讲解

    git stash 是 Git 提供的一个强大的工具,它允许你临时保存(或“暂存”)当前工作目录和索引(暂存区)的改动,从而可以切换分支或执行其他操作而不影响当前的工作状态。下面是 git stash 的一些常用命令及其解释: git stash 这条命令会将当前的工作目录和暂存区的改动保存

    2024年01月24日
    浏览(37)
  • Git reset、revert用法

    reset是删除之前的提交记录,所有的提交点都会被清除,我们看下执行前后的git log区别 执行完成后发现个人分支第三个提交好像从来没有出现过一样,建议不要使用reset,毕竟会把别人的提交点彻底删除 revert 将指定提交的代码给清除掉,提交记录还存在,相当于添加一个新

    2024年02月10日
    浏览(28)
  • git的 reset 和 revert 区别

    线上master分支不可信,需要回到某个分支; 但是很多人习惯把一个需求,分多次commit,于是会出现下面这种情况 基于这种情况,git revert 就不如 git reset好用,可以借助Idea,直接通过 git reset --hard 指向需要回退到的commit,然后随便找个地方,敲上一个空格,产生一次新的commi

    2024年03月21日
    浏览(35)
  • Git 回退(Revert)操作后无法重新合并的问题

    公司使用码云企业版作为代码托管平台,采用master/dev分支分类进行代码管理,matser分支为保护分支,只能审核后在网页端提交合并(请求评审)。 此时dev代码合并到master后发现有问题需要回退上次一合并,此时只能在请求评审处点击回退按钮,回退后master并没有改动,而是

    2024年02月11日
    浏览(32)
  • git 的rebase、reset、revert区别?

    rebase 、 reset 、和 revert 是 Git 中用于修改提交历史的三个不同的命令,它们的作用和效果有所不同。 1. rebase : git rebase 用于将一个分支的提交移到另一个分支上,并重新应用这些提交。主要有两种用途: 整理提交历史 :将多个小的提交合并成一个更为清晰的提交历史,避免

    2024年01月21日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包