放弃本地代码,回到远程仓库

作者:张子健
日期:2025-07-14
本文介绍如何彻底丢弃本地代码,强制回退到远程仓库最新状态。适用于本地代码混乱、需要一键还原的场景。

你要放弃本地的所有更改,直接回到远程仓库的最新状态,可以按照下面的操作来做。这适用于你本地有大量修改、不想要、想完全还原为远程(GitHub)代码的情况。

操作步骤

1. 丢弃本地所有未提交的更改(慎用!)

先确认你的确不需要本地的更改(包括未 add 的和已 add 但未 commit 的)。如果还有重要内容,建议先备份。

git reset --hard
git clean -fd

2. 拉取远程最新代码(强制覆盖本地)

最保险和“一步到位”的做法如下:

git fetch origin
git reset --hard origin/main

3. 如果分支不对,切换到 main(或你需要的分支)

git checkout main

常见误区和补充说明


一步还原(全流程汇总命令)

git fetch origin
git reset --hard origin/main    # 或 origin/master
git clean -fd

如果有文件删除不了/卡住?


总结

一条命令批量给所有子目录加.gitkeep

假设你已经有了src/ tests/ docs/ examples/这些目录, 在项目根目录下,直接执行下面这条 Bash 命令即可:


find . -type d ! -path './.git*' -exec touch {}/.gitkeep \;

解释:

##