赞
踩
很多时候开发一个需求就会拉一个新分支,对完成的需求有一个清晰的记录,有利于需求的管理与维护,也有利于几个需求同时进行
这样通常会有一个问题:当你新需求开发到一半时,上个需求有改变,需要你去完成后再回来接着开发,但是新开发的需求又不想提交
解决方法:
先commit代码,切换分支完成修改后,在回来撤销commit,回到之前状态
git reset --soft HEAD^ (ps:如果控制台出现More?,则将命令改成 git reset --soft HEAD^^即可)
这样就成功的撤销了你的commit
注意,仅仅是撤回commit操作,你写的代码仍然保留。
如果不撤销commit,接着开发,再commit新的进度,在push的时候会push上两条commit的记录,很不优雅
这也适用于,当你开发一个需求开发到一半的时候发现,弄错分支了,需要当前分支回到change之前的状态,在新分支上恢复你开发的内容
暂存代码
它会保存当前工作进度,会把暂存区和工作区的改动保存到一个未完结变更的堆栈中;执行完这个命令后,在运行 git status
命令,就会发现当前是一个干净的工作区,没有任何改动。
git stash
是本地的,不会上传到服务器上;
没有在git 版本控制中的文件,是不能被git stash 存起来的。先执行下git add 加到git版本控制中,然后再git stash就可以了(新增文件时直接add就可以)
satsh之后分支会恢复到开发之前的状态;
切换分支解决完问题后,恢复暂存:
暂存区,会有你所有的暂存信息,选择要恢复的暂存信息:
如上所示,你在不同分支上的stash都会显示出来,所以也适用于,当你开发一个需求开发到一半的时候发现,弄错分支了,需要当前分支回到change之前的状态,在新分支上恢复你开发的内容
结果全部clear掉了
因为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的内容会直接恢复到工作区,并且是未提交的状态
drop才是删除一条stash
快捷键操作太危险,还是命令操作安全:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。