这两个命令长得像、都能"回到过去",但核心逻辑、操作范围、安全性天差地别,一句话先点破:
✅ git restore --source 提交id :文件级 操作,只恢复文件内容,不删提交历史、不改动分支 ,安全无风险
❌ git reset --hard 提交id :仓库级 操作,直接回退整个版本,删除提交历史、清空所有修改,高危命令
下面用通俗解释+核心区别+场景示例讲透,一看就懂:
一、核心本质区别(最关键)
1. git restore --source <commit-id>
作用 :把指定文件(或所有文件) 恢复到「某次提交」的状态
范围 :只动文件内容
分支/提交历史 :完全不动 !之前的所有提交都还在
安全性 :✅ 非常安全,误操作可轻松找回
2. git reset --hard <commit-id>
作用 :把整个仓库 强制回退到「某次提交」的状态
范围 :动分支指针 + 暂存区 + 工作区 全部内容
分支/提交历史 :直接删除 该提交之后的所有提交 !历史被改写
安全性 :❌ 极度危险,未提交的修改、后续提交会直接丢失
二、3个维度直观对比
| 维度 | git restore --source 提交id |
git reset --hard 提交id |
|---|---|---|
| 操作级别 | 文件级(只改文件) | 仓库级(改整个版本) |
| 提交历史 | 完全保留,不删除任何提交 | 删除目标提交之后的所有提交 |
| 工作区/暂存区 | 只替换指定文件,其他修改保留 | 强制清空,所有未提交修改直接丢失 |
| 分支指针 | 不动,停在当前最新提交 | 直接跳转到目标提交,分支位置被改写 |
| 风险等级 | 安全(无数据丢失风险) | 高危(易丢失代码) |
| 核心用途 | 修复单个/多个文件到历史版本 | 彻底废弃后续所有修改,回退整个项目版本 |
三、通俗比喻(秒懂)
git restore --source= 你把笔记本里的某一页撕下来,换回旧的那一页,笔记本的其他页、页码都没变git reset --hard= 你把笔记本直接翻到某一页,后面所有页全部撕掉扔掉,再也找不回来
四、实际用法示例
1. 安全用法:git restore --source
场景:只想把 README.md 恢复到 3天前的提交(id: a1b2c3),其他文件不动
bash
# 只恢复单个文件
git restore --source a1b2c3 README.md
# 恢复当前目录所有文件(不删提交)
git restore --source a1b2c3 .
✅ 结果:只有文件内容变了,提交历史、分支都完好
2. 高危用法:git reset --hard
场景:项目写崩了,后面3次提交全不要了,彻底回到版本 a1b2c3
bash
git reset --hard a1b2c3
❌ 结果:
- 分支指针直接跳到 a1b2c3
- a1b2c3 之后的3次提交全部消失
- 工作区所有未提交修改直接清空
五、总结(必记)
- 只改文件、想保留提交历史 → 用
git restore --source 提交id(安全首选) - 彻底废弃后续所有修改、回退整个项目 → 用
git reset --hard 提交id(谨慎使用) - 新手绝对不要随便用
git reset --hard,极易丢代码!