# 23. Git 內幕:直接處理 Git 對象
## 目的
瀏覽對象存儲的結構。
> 學習如何使用 SHA1 哈希來查找倉庫中 的內容。
現在讓我們使用一些工具來直接探究 Git 對象。
### 查找最新的提交
```
$ git hist --max-count=1
```
這應當顯示倉庫中所做的最新提交。在你的系統中的 SHA1 哈希也許與我的不同,但應該看起來類似。
```
$ git hist --max-count=1
* 96ee164 2013-04-13 | Added a Rakefile. (HEAD, master) [Jim Weirich]
```
### 轉存最新的提交
使用上面所列提交的 SHA1 哈希。
```
$ git cat-file -t <hash>
$ git cat-file -p <hash>
```
這兒是我的輸出:
```
git cat-file -t 96ee164
commit
$ git cat-file -p 96ee164
tree 096b74c56bfc6b40e754fc0725b8c70b2038b91e
parent 0f36766e05bc55d765ec8afe288430edc69fceea
author Jim Weirich <jim (at) neo.com> 1365880844 -0400
committer Jim Weirich <jim (at) neo.com> 1365880844 -0400
Added a Rakefile.
```
注意:如果你在別名實驗中定義了 `type` 和 `dump` 別名,那么 你可以輸入 `git type`和 `git dump`,而不是更長的 `cat-file` 命令(我從未記住過)。
這是 `master` 分支頭提交對象的轉存結果。它看起來很像先前介 紹的提交對象。
### 查找 Tree
我們可以轉存提交中的目錄樹引用。這應當是我們項目中的文件的 說明。使用上面所列“tree”那行的 SHA1 哈希。
```
$ git cat-file -p <treehash>
```
這兒是我的目錄樹看起來的樣子……
```
$ git cat-file -p 096b74c
100644 blob 28e0e9d6ea7e25f35ec64a43f569b550e8386f90 Rakefile
040000 tree e46f374f5b36c6f02fb3e9e922b79044f754d795 lib
```
是的,我看到了 Rakefile 和 lib 目錄。
### 轉存 lib 目錄
```
$ git cat-file -p <libhash>
```
```
$ git cat-file -p e46f374
100644 blob c45f26b6fdc7db6ba779fc4c385d9d24fc12cf72 hello.rb
```
這是 hello.rb 文件。
### 轉存 hello.rb 文件
```
$ git cat-file -p <rbhash>
```
```
$ git cat-file -p c45f26b
# Default is World
# Author: Jim Weirich (jim@somewhere.com)
name = ARGV.first || "World"
puts "Hello, #{name}!"
```
你已經有它了。我們直接從 Git 倉庫轉存了提交對象、樹對象、 以及 blob 對象。blob、樹及提交就是全部了。
### 瀏覽你自己的 Git 倉庫
手動瀏覽你自己的 Git 倉庫。看看是否能通過遵循最新提交的 SHA1 哈希引用來從第一個提交找出最初的 hello.rb 文件。
- 關于
- 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. 高級/將來的主題