一、使用场景
当在开发新功能的过程中,新功能尚未开发完成,而且如果此时将代码提交会导致程序运行失败,而正在这个时候上一个版本出现bug需要紧急修复,此时希望的操作时将当前新功能开发代码找其他地方存起来,即让当前代码仓的代码回到上个提交状态,然后修复bug,待bug修复后提交到代码仓上线后,再将刚刚开发的新功能的代码拿到当前的代码仓继续新功能的开发,git stash命令就可以很好的解决这种使用场景的问题
二、使用流程
(1) 查看当前状态
此时,可以看出当前有许多文件或代码处于尚未add的状态
git status
(2) 将这些新功能的不完整的代码找一个地方暂时存放起来,让当前代码仓回到之前提交的状态
git stash
(3) 查看当前状态
此时可以发现当前代码仓已经没有修改状态的代码了,打开代码文件也可以发现此时的代码处于上次提交状态的代码,刚刚开发的新功能的代码已经不见了
git status
(4)此时可以进行bug修复,bug修复完成后,可参照如下流程讲修复bug的代码提交到远端代码仓
git add .
git commit -m "xxx"
git push origin xxxx_branch
(5)将刚刚新功能开发的代码捞回来
git stash pop
(6)继续进行新功能的代码开发即可
三、git stash相关命令解释
git stash 将当前工作区所有修改多的内容存储到某个位置,将工作区还原到上个提交状态
git stash list 查看之前使用的git stash命令的记录
git stash clear 将之前使用git stash存储起来的修改全部清空
git stash pop 将上次使用git stash暂存起来的修改代码捞回来到工作区
git stash apply xxx 通过指定git stash历史记录的id将之前某一次使用git stash保存起来的修改的代码捞回来到工作区
git stash drop xxx 通过指定git stash历史记录的id将之前某一次使用git stash保存起来的修改彻底丢弃掉