# 16. 撤销提交的更改
## 目的
> 学习如何还原已经提交到本地仓库的更改。
### 撤销提交
有时候你意识到已经提交的更改不正确并想撤销该提交。有 几种方式可以处理这种问题,我们在本实验中所用的方式总 是安全的。
实际上我们将通过创建新的提交来撤销原来不想要更改的提 交。
### 更改文件并提交
更改 hello.rb 文件成下列内容:
```
# This is an unwanted but committed change
name = ARGV.first || "World"
puts "Hello, #{name}!"
```
```
$ git add hello.rb
$ git commit -m "Oops, we didn't want this commit"
```
### 创建还原提交
要撤销已提交的更改,我们需要创建一个提交来移除由不想 要的提交所引入的更改。
```
$ git revert HEAD
```
这将带你到编辑器中。你可以编辑默认的提交信息,或直接 离开它。保存并关闭文件。你应该看到:
```
$ git revert HEAD --no-edit
[master a10293f] Revert "Oops, we didn't want this commit"
1 files changed, 1 insertions(+), 1 deletions(-)
```
因为我们将撤销我们做的最后提交,所以我们可以使用 `HEAD` 作为还原的参数。通过简单的指定哈希值,我们可以撤销早期 历史中的任意提交。
注意:命令中的 `--no-edit` 可被忽略。在不打开编辑器生成输 出时需要它。
### 检查日志
检查日志来显示我们仓库中不想要及还原的提交。
```
$ git hist
```
```
$ git hist
* a10293f 2013-04-13 | Revert "Oops, we didn't want this commit" (HEAD, master) [Jim Weirich]
* 838742c 2013-04-13 | Oops, we didn't want this commit [Jim Weirich]
* 1f7ec5e 2013-04-13 | Added a comment (v1) [Jim Weirich]
* 582495a 2013-04-13 | Added a default value (v1-beta) [Jim Weirich]
* 323e28d 2013-04-13 | Using ARGV [Jim Weirich]
* 9416416 2013-04-13 | First Commit [Jim Weirich]
```
这种技术将处理任何提交(虽然你可能必须解决冲突)。在 公开分享的远程仓库上使用分支更加安全。
### 下一步
接下来,让我们看看从仓库历史中移除最近提交所用的技术。
- 关于
- 1. 设置
- 2. 再谈设置
- 3. 创建项目
- 4. 检查状态
- 5. 做更改
- 6. 暂存更改
- 7. 暂存与提交
- 8. 提交更改
- 9. 更改而非文件
- 10. 历史
- 11. 别名
- 12. 获得旧版本
- 13. 给版本打标签
- 14. 撤销本地更改
- 15. 撤销暂存的更改
- 16. 撤销提交的更改
- 17. 从分支移除提交
- 18. 移除 oops 标签
- 19. 修正提交
- 20. 移动文件
- 21. 再谈结构
- 22. Git 内幕:.git 目录
- 23. Git 内幕:直接处理 Git 对象
- 24. 创建分支
- 25. 导航分支
- 26. 在 master 中更改
- 27. 查看分叉的分支
- 28. 合并
- 29. 创建冲突
- 30. 解决冲突
- 31. 变基 VS 合并
- 32. 重置 greet 分支
- 33. 重置 master 分支
- 34. 变基
- 35. 合并回 master
- 36. 多个仓库
- 37. 克隆仓库
- 38. 回顾克隆的仓库
- 39. 何为 Origin?
- 40. 远程分支
- 41. 更改原始仓库
- 42. 取得更改
- 43. 合并拉下的更改
- 44. 拉下更改
- 45. 添加跟踪的分支
- 46. 裸仓库
- 47. 添加远程仓库
- 48. 推送更改
- 49. 拉下共享的更改
- 50. 托管你的 Git 仓库
- 51. 共享仓库
- 52. 高级/将来的主题