G20峰会将在中国召开?官方最新回应来了
时间:2026-05-26 20:24:29 462浏览 收藏
本文澄清了Git中一个常见却易被误解的设计行为:git pull不会自动恢复本地已被删除的文件,这并非程序缺陷,而是Git有意为之——它将本地删除视为主动操作,优先尊重开发者意图;文章深入解释了pull本质为fetch+merge、仅影响未修改文件和提交历史的底层逻辑,并提供了安全高效的恢复方案(如git restore或git checkout HEAD --),同时警示了git reset --hard等危险操作的风险与适用边界,强调日常开发中养成git status检查和谨慎操作习惯的重要性。

Git 仓库里删掉的文件,git status 显示为 deleted,但 git pull 不会自动恢复它——这不是 bug,是设计如此。
为什么 git pull 不恢复本地已删的文件
Git 的 pull 本质是 fetch + merge(或 rebase),只影响「当前分支的提交历史」和「工作区中未被修改的文件」。如果某个文件在本地被 rm 删除,而该文件在远程最新提交中仍存在,Git 默认认为这是你**主动删的**,不会反向覆盖你的操作。
git pull不会触碰你已git add过、又手动删掉的文件(即处于deleted状态)- 即使该文件在远程最新 commit 中存在,也不会自动 checkout 回来
- 只有当文件在本地被修改过(
modified),且远程也改了,才可能触发合并冲突;纯删除不触发任何恢复逻辑
怎么把删掉的文件快速找回来
最直接的办法是用 git checkout 或 git restore(Git 2.23+)从暂存区或 HEAD 拉回来:
- 从暂存区恢复(推荐,安全):
git restore(如果文件还在暂存区) - 从最近一次 commit 恢复:
git checkout HEAD -- - 批量恢复所有已删文件:
git status --porcelain | awk '/^D / {print $2}' | xargs git checkout HEAD -- - 注意:
git checkout(无--)会尝试切换分支,容易误操作,务必加--
git reset --hard HEAD 能不能用
能,但太重——它会把所有未提交的修改(包括你编辑过的其他文件)全部丢弃,不只是恢复删掉的文件。
- 仅当你确认「所有未提交变更都不要了」时才用
- 执行前建议先运行
git status看一眼,避免误清 - 比
git restore或git checkout HEAD --更难回退(需依赖 reflog) - 在共享分支上慎用,尤其已
git add过某些改动后又想局部撤销
真正容易被忽略的是:Git 不区分「我删的」和「我忘了保存就关了编辑器导致的丢失」——它只认索引(staging)和工作区状态。所以日常开发中,别等 git pull 救你,删之前先 git ls-files | grep xxx 确认,或者养成 git status 后扫一眼的习惯。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
296 收藏
-
231 收藏
-
322 收藏
-
308 收藏
-
349 收藏
-
432 收藏
-
463 收藏
-
220 收藏
-
239 收藏
-
163 收藏
-
462 收藏
-
410 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习