前提
Unstaged changes after reset
这是最近学习git撤销命令时,遇到的提示,它的直译是“撤销后未暂存的修改”,它只是告诉你撤销以后有哪些文件需要被暂存,但是百度查到的一些博客,感觉说的不太对,这里写个笔记记录一下自己的理解。
开发工具
VSCode,他的git操作结果可视化真的帮了大忙。
这里放一张图,先了解一下git里本地、暂存区、本地仓库、远程仓库的关系,
这张图是CSDN博主茁壮成长的凌大大 的博客git代码撤销回滚只看这一篇就足够了!里的,谢谢大佬。
问题来源
代码修改后,出现这个提示,一般有2种可能
1.代码添加到暂存区,还没commit到本地仓库的时候执行了撤销命令且本地文件没有删除
执行
git add .
再执行
git reset
或
git reset head
或
git reset --mixed
2.代码暂存了,也commit到本地仓库了,执行了撤销命令且本地文件没有删除
执行
git add .
git commit -m 'xxx'
再执行
git reset --mixed head~1
或
git reset --mixed head^1
或
git reset --mixed sha值
sha值是commit的sha值
思路
1.上面2种情况都强调了本地文件暂存,且撤销后没有删除本地文件,是因为如果执行的是soft或者hard不会出现这个提示,soft是因为文件还在暂存区,hard是因为修改的地方不存在了被清掉了
2.出现这个提示以后,代码本身并没有什么问题,只是撤销了暂存和commit,恢复到了执行git命令以前,可以选择是否修改代码,接下来再看自己需要执行何种git命令
2.1 代码修改后想重新commit
先修改代码
git add .
git commit -m 'xxx'
2.2 不修改代码,只是想恢复到上一次commit的代码
1.安全起见,备份代码到分支
先提交到本地仓库
git add .
git commit -m 'xxx'
新建分支
git checkout -b xxx
或
git branch xxx
git checkout xxx
再切回当前分支
git checkout yyy
再退回之前的commit版本,因为hard会删除修改内容,误删就麻烦了
git reset --hard head~1
或
git reset --hard head^1
或
git reset --hard sha值
2.完全不虚,不备份代码,直接把修改的代码删除,恢复到上一次commit的状态
git checkout -- .
版权归原作者 那个发饰 所有, 如有侵权,请联系我们删除。