git checkout和git reset
时间: 2025-01-10 16:56:27 浏览: 75
### 比较 `git checkout` 和 `git reset`
#### 功能差异
`git checkout` 主要用于切换分支或恢复工作目录中的文件状态。此命令可以用来检出特定版本的文件或将当前的工作区切换到另一个分支,而不会改变HEAD指针所指向的位置除非明确指定分支名[^1]。
对于 `git reset` 而言,其功能更为强大也更复杂一些。它可以回滚提交历史记录,更改暂存区域的内容,并且可以选择性地影响工作树的状态。通过不同的选项参数(如`--soft`, `--mixed`, 或者 `--hard`),能够实现不同程度上的重置操作[^3]。
#### 使用场景对比
- **处理未跟踪的新文件**
如果只是想要取消对新创建但尚未加入仓库追踪列表里的文件所做的修改,则应该使用 `git checkout -- <file>` 命令来丢弃本地变更并保留新增加过的那些文件;而对于已经处于索引之中却不想再继续保留改动的情况来说,应当采用 `git reset HEAD <file>` 加上后续的手动删除动作[^4]。
- **撤销最近的一次提交**
若要撤消最新的那次提交但是仍然希望保存已做的更改以便稍后再做调整的话,那么就适合运用带有 `--soft` 参数形式下的 `git reset HEAD~1` 。这会使得最新一次提交消失不见,不过所有被改过的文档依旧保持在暂存区内等待着下次提交时一并纳入其中。
- **回到之前的某个提交点**
当需要完全抛弃自某次特定提交之后发生的一切变化直至达到那个时间点之前的样子时,可借助于带 `--hard` 参数执行像这样的指令序列:先定位至目标位置即 `git reset --hard <commit-id>` ,接着清理掉任何残留下来的未跟踪项以防万一有遗漏之处存在——可以通过运行额外一条语句 `git clean -fd` 完成这项任务。
```bash
# 取消单个文件的修改, 并将其从暂存区移除
git reset HEAD <file>
# 放弃对新文件的修改而不删除它本身
git checkout -- <new-file>
```
阅读全文
相关推荐




















