Git-stash产生的冲突

场景简介

环境:Windows 10,Git 2.45.1,分支 dev 操作:在干净工作区上执行 git stash pop,试图恢复之前保存的改动。

问题现象

git stash pop 之后,文件 app/Services/Demo.php出现冲突,git status 显示为:

sql 复制代码
Unmerged paths:
       both modified: app/Services/Demo.php

在 SourceTree 中,这个文件同时出现在「已暂存」和「未暂存」区域。 尝试用 git restore 放弃修改,报错:

lua 复制代码
error: path 'xxx' is unmerged

原因分析:什么是 Unmerged paths?

git stash pop 本质是一次 三方合并(当前 HEAD + 当前工作区 + stash 内容)。 合并时这个文件发生冲突,Git 在索引中为它保存了多份版本(base/ours/theirs),标记为 未合并(unmerged)。 在这种状态下,很多命令(包括 git restore)会拒绝操作,防止破坏合并过程,所以会提示 path 'xxx' is unmerged。

最终解决方案

需求:完全放弃这次 stash pop 带来的所有改动,恢复到 pop 前的干净状态,且确认没有其他需要保留的本地修改。执行步骤:

perl 复制代码
# 1. 丢弃所有本地未提交修改(包括冲突)
git reset --hard HEAD
# 2. 确认工作区干净
git status  # 显示 working tree clean
# 3. 同步远程最新提交
git pull

结果:

冲突文件恢复为 HEAD 版本,不再是 Unmerged paths。 工作区与暂存区都干净,只多了远程新拉下来的正常变更。 这次 stash pop 的所有本地影响被彻底清除。

经验总结

stash pop 会触发合并冲突,出现 Unmerged paths 非常正常。 看到 Unmerged paths 时,要意识到:当前还处在一次「未完成的合并过程」。 如果确认当前所有未提交改动都可以丢弃,一键回到干净状态的最简单办法就是: git reset --hard HEAD 操作前务必用 git status / git diff 确认:真的没有其他想保留的本地修改。

清理掉贮藏区 git stash clear

相关推荐
UrbanJazzerati3 小时前
Python Scrapling反爬虫小技巧之Referer
后端·面试
程序员爱钓鱼3 小时前
Go语言WebP图像处理实战:golang.org/x/image/webp
后端·google·go
Nanjo_FanY3 小时前
Spring Boot 3/4 可观测落地指南
后端
PFinal社区_南丞3 小时前
Go语言开发AI智能体:从Function Calling到Agent框架
后端·go
货拉拉技术4 小时前
货拉拉海豚平台-大模型推理加速工程化实践
人工智能·后端·架构
神奇小汤圆4 小时前
请不要自己写,Spring Boot非常实用的内置功能
后端
神奇小汤圆4 小时前
突破Netty极限:基于Java 21 FFM API手写高性能网络通信框架
后端
Java编程爱好者4 小时前
给 Spring Boot 接口加了幂等保护:Token 机制 + 结果缓存,一个注解搞定
后端
Java编程爱好者5 小时前
字节二面:Redis 能做消息队列吗?怎么实现?
后端