## 目的
> 學習如何還原已經提交到本地倉庫的更改。
### 撤銷提交
有時候你意識到已經提交的更改不正確并想撤銷該提交。有 幾種方式可以處理這種問題,我們在本實驗中所用的方式總 是安全的。
實際上我們將通過創建新的提交來撤銷原來不想要更改的提 交。
### 更改文件并提交
更改 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. 高級/將來的主題