## 目的
> 學習如何還原已經暫存的更改。
### 更改文件并暫存更改
修改 hello.rb 文件來包含一個錯誤的注釋。
~~~
# This is an unwanted but staged comment
name = ARGV.first || "World"
puts "Hello, #{name}!"
~~~
然后去暫存它。
~~~
$ git add hello.rb
~~~
### 檢查狀態
檢查你不想要的更改狀態。
~~~
$ git status
~~~
~~~
$ git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: hello.rb
#
~~~
`status`?輸出顯示更改已被暫存且準備提交。
### 重置暫存區
幸運的是?`status`?輸出告訴我們取消暫存更改時需要做什么。
~~~
$ git reset HEAD hello.rb
~~~
~~~
$ git reset HEAD hello.rb
Unstaged changes after reset:
M hello.rb
~~~
`reset`?命令重置 HEAD 中暫存區的內容。這將清除我們已經暫存 的更改。
`reset`?命令(默認)不會更改工作目錄。所以在工作目錄中仍然 有不想要的注釋。我們可以使用之前實驗中的?`checkout`?命令來 從工作目錄移除不想要的更改。
### 檢出提交的版本
~~~
$ git checkout hello.rb
$ git status
~~~
~~~
$ git status
# On branch master
nothing to commit (working directory clean)
~~~
現在我們的工作目錄又變干凈了。
- 關于
- 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. 高級/將來的主題