需求:
很多时候开发一个需求就会拉一个新分支,对完成的需求有一个清晰的记录,有利于需求的管理与维护,也有利于几个需求同时进行
这样通常会有一个问题:当你新需求开发到一半时,上个需求有改变,需要你去完成后再回来接着开发,但是新开发的需求又不想提交
解决方法:
方法1:(不推荐,只能一个分支进行操作)
先commit代码,切换分支完成修改后,在回来撤销commit,回到之前状态
1:正常流程的commit代码,不push
2:撤销 git commit
git reset --soft HEAD^ (ps:如果控制台出现**More?**,则将命令改成 git reset --soft HEAD^^即可)
这样就成功的撤销了你的commit
注意,仅仅是撤回commit操作,你写的代码仍然保留。
如果不撤销commit,接着开发,再commit新的进度,在push的时候会push上两条commit的记录,很不优雅
方法2:(推荐,可以不同分支进行操作)
这也适用于,当你开发一个需求开发到一半的时候发现,弄错分支了,需要当前分支回到change之前的状态,在新分支上恢复你开发的内容
git stash:
暂存代码
它会保存当前工作进度,会把暂存区和工作区的改动保存到一个未完结变更的堆栈中;执行完这个命令后,在运行
git status
命令,就会发现当前是一个干净的工作区,没有任何改动。
git stash
是本地的,不会上传到服务器上;
新增的文件,直接执行stash是不会被存储的:
没有在git 版本控制中的文件,是不能被git stash 存起来的。先执行下git add 加到git版本控制中,然后再git stash就可以了(新增文件时直接add就可以)
操作演示:
idea上操作git stash:
填写暂存信息:
satsh之后分支会恢复到开发之前的状态;
恢复暂存:
切换分支解决完问题后,恢复暂存:
暂存区,会有你所有的暂存信息,选择要恢复的暂存信息:
如上所示,你在不同分支上的stash都会显示出来,所以也适用于,当你开发一个需求开发到一半的时候发现,弄错分支了,需要当前分支回到change之前的状态,在新分支上恢复你开发的内容
删除不需要的stash信息:(下面是错误操作,切勿模仿)
结果全部clear掉了
git stash clear了,找回误删的stash:
因为stash也有对应的栈缓存用来保存log,所以可以通过以下命令查出
git log --graph --oneline --decorate $( git fsck --no-reflog | awk '/dangling commit/ {print $3}' )
tips:这个命令只能在git bash中使用,否则无法识别awk;只能执行前面一半的命令,查出提交记录:
在git bash中使用:
找到你要恢复的stash
git stash apply +编号
这个stash的内容会直接恢复到工作区,并且是未提交的状态
正确的删掉不需要的暂存stash:
drop才是删除一条stash
命令操作:
快捷键操作太危险,还是命令操作安全:
git stash list :
版权归原作者 admiraldeworm 所有, 如有侵权,请联系我们删除。