1、首先咱们先谈谈git 添加暂存区 以及 代码库生成commit 然后上传到远程代码库的过程
通常我们提交代码一般都是 git add,git commit -m, git push的这么个流程。添加到暂存区,提交到git库生成版本号,push到远程仓库以供他人可以使用。这是一个完整的且非常顺利的流程。但是往往实际开发中并不是这么顺利,总会出现这样或那样的问题。
2、再来说说git reset的作用
1、git reset就是当我们提交了错误的内容后进行回退使用的命令。
2、git reset使用方法:git reset 版本号,就是回退到该版本号上。
3、git reset HEAD就是回退到当前版本。git reset HEAD^回退到上一版本。
3、清楚了这些过程以及用法 大家可以自己实操一下
过程 git add 一个文件,添加一个错误的内容,此时我们只是做了add 操作,就是将修改了内容添加到了暂存区,还没有执行commit,所以还没有生成版本号,当前的版本号对应的内容,还是你add之前的内容,所以我们只需要将代码回退到当前版本就行。git reset HEAD ,就是去除掉添加到暂存区的内容。 执行命令后,当前的git 状态,查看状态,发现和我们修改了工作区的内容,还没有add时的状态是一样的了。说明git reset HEAD操作只对暂存区起效果,不对工作区的内容起效果。
所以我们要想修改掉工作区的内容还得继续执行命令进行还原。命令为:git checkout – to discard changes in working directory这个意思就是把文件还原了,工作区的修改也没了。此时你去看工作的文件修改的地方就会已经没有了,工作区文件也干净了,算是彻底把文件还原了。这次形容的场景是add后还没有commit的。
4、我们看一下已经add并且commit之后的该如何
我们先说一下push:push的内容我们不管,push这个命令其实和提交没关系,他只是推送到远程了,如果push了,也就是我们回退了之后,再重新push一下而已,所以请不要纠结push这个操作。他和提交版本其实没有关系的。
我们已经commit了,说明已经生成了最新的版本号了,此时我们想回退,则肯定是回退到之前的一个版本了,如果你知道前一个版本的版本号,git reset 版本号,这样就可以了,或者可以执行git log命令去查到。git为我们提供了一个更简单的回退上一个版本的方法 git reset HEAD^,此命令专门用于回退到上一个版本,如果你的错误路程已经走的很远了,仅仅回退上一个版本可能也解决不了了,那就需要查找日志,找到对应的版本号进行git reset 版本号进行回退了。我们执行 git reset HEAD^后,效果跟没有commit一样。
5、重点来了 在 git reset上加 --hard是啥作用呢?
同样的,我们先add,不进行commit操作,add后,我们执行 git reset --hard HEAD,然后我们执行git status查看状态,这里和没有--hard是有区别的了,有了参数--hard, 直接把工作区的内容也修改了,不加--hard的时候只是操作了暂存区,不影响工作区的。--hard一步到位,不加--hard需要分开执行,两步操作。虽然看上去加了--hard方便了好多,但是我不建议大家使用这个,这个命令比较可怕。 最后这里说一下 加了--hard的,有没有commit的是没有区分的。