如果你想取消本地仓库里的所有修改,可按以下情形操作:
情况一:修改了文件,但还没执行 git add
要是你已经修改了文件,不过还没把这些修改添加到暂存区(也就是还没执行 git add
),可以使用 git checkout
命令来撤销工作区的修改。
bash
# 撤销所有文件的修改
git checkout .
# 或者撤销指定文件的修改
git checkout <file-path>
情况二:已执行 git add
,但未执行 git commit
当你已经把修改添加到暂存区(执行了 git add
),但还没有提交(未执行 git commit
),可以使用 git reset
和 git checkout
命令组合来处理。
bash
# 取消暂存区的所有修改,让文件回到未add的状态
git reset HEAD
# 然后撤销工作区的修改
git checkout .
情况三:已经执行了 git commit
若你已经提交了修改(执行了 git commit
),不过想撤销这个提交,可以使用 git reset
命令。
bash
# 回退到上一个提交,保留工作区的修改
git reset HEAD~1
# 回退到上一个提交,并且丢弃工作区的修改(谨慎使用)
git reset --hard HEAD~1
情况四:想要丢弃所有本地修改,直接让工作区和仓库完全一样
若你想彻底丢弃所有本地修改,让工作区的内容和仓库完全一致,可以使用 git reset --hard
命令。
bash
# 重置暂存区和工作区,使它们和HEAD指向的最新提交保持一致
git reset --hard HEAD
注意事项
- 谨慎使用
git reset --hard
:这个命令会永久删除所有未提交的修改,一旦执行就无法恢复。 - 备份重要数据:在执行任何可能删除数据的操作之前,先备份重要的修改。
- 查看状态:执行
git status
可以查看当前的修改状态,避免误操作。