git push提交成功后如何撤销回退

git push提交成功后如何撤销回退1.写在前面  我们在使用Git进行版本控制时,有可能会出现这种情况。gitpush后发现提交的内容不是想要的,这时候我们怎么做呢,提交上去的内容是没有删除按钮的(比如github,或码云)。所以我们需要一些手段将提交上去内容撤销下来。2.解决  首先将本地的内容回退到自己想要的版本。回退版本我一般使用gitreset  其中这条命令中又分为两种gitreset–hard

https://guozh.net/?p=166

前言

我们在使用Git进行版本控制时,有可能会出现这种情况。git push后发现提交的内容不是想要的,这时候我们怎么做呢,提交上去的内容是没有删除按钮的(比如github,或码云)。所以我们需要一些手段将提交上去内容撤销下来。

解决

首先将本地的内容回退到自己想要的版本。回退版本我一般使用

git reset

其中这条命令中又分为两种

git reset –hard git reset –soft

注意上者的区别,在说这两者区别前,我们首先要明白一个东西,commits,它在git中扮演了一个重要角色,我们平常用的一些操作git clone ,git commit 都会产生commits,通俗的讲这个就是版本号,但是git reset并不会产生commits(不是不会产生,而是会产生 但是都是一样的),我们可以先看看自己项目中的commits,使用如下命令

git reflog

这里写图片描述

看到没前面那一串数字就是commits,所以git reset可以看成不产生commits,它只是改变了当前HEAD指向的commits。

  • git reset –soft
  • git reset –hard

前者表示只是改变了HEAD的指向,本地代码不会变化,我们使用git status依然可以看到,同时也可以git commit提交。后者直接回改变本地源码,不仅仅指向变化了,代码也回到了那个版本时的代码,所以使用是一定要小心,想清楚。

然后再来看回退,如果只是回退到上个版本可以使用

git reset –soft xx版本号xxxx git reset –hard xx版本号xxx

也可以使用

git reset –soft HEAD~1 git reset –hard HEAD~1

因为前面说了HEAD就代表当前,所以上一个版本其实就是当前-1,我们也可以用

git reset HEAD

试一试,并不会有什么变化,因为HEAD就是当前。这里我们先使用

git reset –soft HEAD~1

我们可以知道其实HEAD已经指向上一个commits了,我们可以是用git reflog验证下


这里写图片描述

我们再使用git status看看,发现没,代码还在缓存区中


这里写图片描述

这时候就好办了,我们选择很多,可以直接修改代码,再commit,也可以取消git add 命令,指令如下

git rm –cached xxx文件名xxx git rm

至于这两者的区别看这里吧
[GIT]代码在GIT ADD之后如何取消 ok 到现在为止,本地的版本已经达到我们想要的了,现在只需要改变远程仓库的版本了,对的,我们只需要在git commit 后,再使用 git push origin 分支名 就可以将新的代码覆盖掉远程仓库版本代码,这样子就达到了撤销远程仓库代码一样的效果,但是这里有点点问题,先接着看吧


这里写图片描述

提交失败,因为当前分支的版本低于远程分支的版本,所以要想覆盖掉它,必须使用force

git push origin 分支 –force ok,大功告成

 

推荐阅读 启发!这几个日流量上百万的台湾农场采集站值得一看

今天的文章git push提交成功后如何撤销回退分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/25152.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注