1.写在前面我们在使用Git进行版本控制时,有可能会出现这种情况。git push后发现提交的内容不是想要的,这时候我们怎么做呢,提交上去的内容是没有删除按钮的(比如github,或码云)。所以我们需要一些手段将提交上去内容撤销下来。 2.解决首先将本地的内容回退到自己想要的版本。回退版本我一般使用
其中这条命令中又分为两种
注意上者的区别,在说这两者区别前,我们首先要明白一个东西,commits,它在git中扮演了一个重要角色,我们平常用的一些操作git clone ,git commit 都会产生commits,通俗的讲这个就是版本号,但是git reset并不会产生commits(不是不会产生,而是会产生 但是都是一样的),我们可以先看看自己项目中的commits,使用如下命令
前者表示只是改变了HEAD的指向,本地代码不会变化,我们使用git status依然可以看到,同时也可以git commit提交。后者直接回改变本地源码,不仅仅指向变化了,代码也回到了那个版本时的代码,所以使用是一定要小心,想清楚。
也可以使用
因为前面说了HEAD就代表当前,所以上一个版本其实就是当前-1,我们也可以用
试一试,并不会有什么变化,因为HEAD就是当前。这里我们先使用
我们可以知道其实HEAD已经指向上一个commits了,我们可以是用git reflog验证下
我们再使用git status看看,发现没,代码还在缓存区中
至于这两者的区别看这里吧[GIT]代码在GIT ADD之后如何取消
(责任编辑:IT) |