更新时间:2022-06-22 来源:黑马程序员 浏览量:
1、解决思路
在工作过程中,当你正在当前feature分支上进行功能的开发,突然来了一个bug,要创建一个bugfix修复分支进行修复。但是当前feature分支你只开发了一半,显然你去提当前的半成品是不合适的,我们如何处理此类问题,来大家看下一图解:
我们用到的关键命令:
```properties
#创建Stash 工作点:
git stash save "干活干到一半"
#查看stash list
git stash list
恢复方式一:
# apply恢复后手动drop清除stash
$ git stash apply
$ git stash drop
# 多个stash时,恢复指定stash需加上id, 如
$ git stash apply stash@{0}
恢复方式二:
# 恢复最近一次stash到栈中的内容到工作区,恢复后删除此stash
git stash pop
# 同理 有多个存储时
git stash pop stash@{0}
```
2、动手实践
上图中我们可以看到整个的处理过程,下面我们来看下具体的操作
2.1、基于Idea工具解决
右击项目目录----Git----Reppository----Stash Changes
弹框填上message并勾上keep index方便后面找回,
点击create stash,此时你会发现会得到一个与你master分支内容相同的代码
当然你是不能直接在feature分支上修复bug的,这是你需要切换master分支:
在master主分支基础上创建bugfix分支进行修复
修复bug,并提交到bugfix
再切换master分支,然后续进行bugfix分支的合并
把之前在bugfix分支上修复的代码合并到当前的master分支
bug修复完成后,切回到feature分支,继续工作
找回上一次feature的工作点进行工作
弹出框选择你的工作点,然后点击Apply Stash
2.2、基于Git命令解决
feature分支打代码开发到一半,这时候来了bug需要切换分支修复
创建Stash 工作点:
```properties
#创建Stash 工作点:
git stash save "干活干到一半"
```
此时你再查看App.java代码会发现会得到一个与你master分支内容相同的代码
当然你是不能直接在feature分支上修复bug的,你需要切换master分支:
在master主分支基础上创建bugfix分支进行修复
bugfix代码后进行提交
再切换master分支,然后续进行bugfix分支的合并
合并bugfix代码到master
bug修复完成后,切回到feature分支,继续工作
找回上一次feature的工作点进行工作
```properties
#stash列表查看
git stash list
```
```properties
# apply恢复后手动drop清除stash
$ git stash apply
$ git stash drop
```
【AI设计】北京143期毕业仅36天,全员拿下高薪offer!黑马AI设计连续6期100%高薪就业
2025-09-19【跨境电商运营】深圳跨境电商运营毕业22个工作日,就业率91%+,最高薪资达13500元
2025-09-19【AI运维】郑州运维1期就业班,毕业14个工作日,班级93%同学已拿到Offer, 一线均薪资 1W+
2025-09-19【AI鸿蒙开发】上海校区AI鸿蒙开发4期5期,距离毕业21天,就业率91%,平均薪资14046元
2025-09-19【AI大模型开发-Python】毕业33个工作日,就业率已达到94.55%,班均薪资20763元
2025-09-19【AI智能应用开发-Java】毕业5个工作日就业率98.18%,最高薪资 17.5k*13薪,全班平均薪资9244元
2025-09-19