Git -- git stash 暂存

使用 git 或多或少都会了解到 git stash 命令,但是可能未曾经常使用,下面简单介绍两种使用场景。

场景一:分支A开发,分支B解决bug

我们遇到最常见的例子就是,在当前分支 A 上开发写需求,但是 B 分支上有一个 bug 需要解决, 此时不能将 A 分支上的代码抛弃,应该怎么办?

方法一:提交当前分支 A 上的代码,然后再切换分支修改 bug。

但此时会出现,本地的代码有部分不想提交,比如存在一些测试代码,不必要的注释等等,就需要使用下一个方法。

方法二:git stash

bash 复制代码
# 1. 将代码保存到栈中
git stash 

# 2. 切换 B 分支,修改 bug
git checkout B 

# 3. 解决 bug 后,进行一系列 push 操作
git add .
git commit -m 'xxx'
git push

# 4. 切换开发分支 A 
git checkout A

# 5. 将之前的代码拿出来
git stash pop

场景二:解决冲突

在我们提交 commit 代码之前,需要拉取远程的代码,pull 一下,获取最新内容!

此时可能出现一个情况,当我们 push 代码之前,其他同事已经开发完合并代码,如果两个人在同一个文件进行修改,push 代码之后,在远端会出现冲突,为了避免该问题,将其放在本地解决冲突。

但是这个时候,git 不允许我们 pull 拉取代码,提示本地存在未提交代码,这个时候就需要进行下面操作:

bash 复制代码
# 1. 将未提交的改动存放到 git 栈里面
git stash

# 2. 获取远端最新代码
git pull

# 3. 将存放的代码取出
git stash pop

# 4. 本地处理可能出现的冲突

# 5. 提交代码
git commit -m 'xxx'
git push
相关推荐
~央千澈~2 分钟前
git添加远程仓库报错To add an exception for this directory解决方案-优雅草卓伊凡
git
爱吃烤鸡翅的酸菜鱼1 小时前
深度掌握 Git 分支体系:从基础操作到高级策略与实践案例
分布式·git·后端·gitee·github
卡布奇诺-海晨2 小时前
2025版本的idea解决Git冲突
java·git·intellij-idea
好好沉淀9 小时前
ide进去git突然报Cannot identify version of git executable: no response的错误
git
宇宙超级无敌霸王龙捏13 小时前
Git 分支完整操作指南
git
学编程的小鬼16 小时前
git 中常用的命令
git
小黄酥16 小时前
Sourcetree克隆/获取gitee工程,Git获取SSH密钥
git·gitee·github
小Lu的开源日常18 小时前
踩坑日记:为什么 .gitignore 不起作用了
git·代码规范·trae
Gazer_S1 天前
【Git 子模块冲突解析】
git
她说..1 天前
通过git拉取前端项目
java·前端·git·vscode·拉取代码