执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?

执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?

先理解为什么代码会消失

repo sync 中的 -d 参数是关键:它会让每个项目仓库(repo 管理的子 git 仓库)丢弃本地的分支检出状态,强制切换到与远程清单一致的提交版本 ,相当于对每个子仓库执行了类似 git checkout --detach + 丢弃本地未提交 / 未推送的变更(尤其是未跟踪的分支或游离状态的提交)。

但幸运的是,git 不会轻易彻底删除提交记录,哪怕是被 "覆盖" 的提交,也会在本地保留日志,git reflog 就是用来找回这些 "隐藏" 提交的。

完整恢复步骤

复制代码
git reflog

git show b26a8f71

方法1:

git checkout b26a8f71

方法2:

# 1. 确保当前在你需要的分支(比如master)

git checkout master

# 2. 捡取丢失的提交到当前分支

git cherry-pick b26a8f71


以后这样操作,不要加 -d选项
# 1. 切换到开发分支
repo forall -c 'git checkout feature/my-feature'
repo forall -c 'git checkout al_dev'
 
# 2. 只同步这个分支的最新代码
repo sync -c -j8
相关推荐
noravinsc4 小时前
关于Git Flow
git
蜜獾云5 小时前
在Git中配置用户名和密码
git
scx_link6 小时前
通过git bash在本地创建分支,并推送到远程仓库中
开发语言·git·bash
南大白8 小时前
IntelliJ IDEA 运行时的 JVM 本地内存溢出崩溃
git
码农小旋风9 小时前
Claude Code 基础用法大全:对话、分析、修改、测试、Git 和工作流
人工智能·git·chatgpt·claude
南大白9 小时前
Git 撤回提交完整方案
git
像风一样的男人@9 小时前
python --实现代理服务器
git·ui
sbjdhjd10 小时前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
码云数智-大飞10 小时前
Go Channel 详解:并发通信的正确姿势
前端·数据库·git
OsDepK19 小时前
OSMDE手机AI编程,一键Git
git·ai编程