我覺得前幾天的 curl 練習進展順利,所以今天我醒來後,想嘗試編寫一些 Git 練習。Git 是一大塊需要學習的技能,可能要花幾個小時才能學會,所以我分解練習的第一個思路是從“導航”一個儲存庫開始的。
我本來打算使用一個玩具測試庫,但後來我想,為什麼不使用真正的儲存庫呢?這樣更有趣!因此,我們將瀏覽 Ruby 程式語言的儲存庫。你無需瞭解任何 C 即可完成此練習,只需熟悉一下儲存庫中的檔案隨時間變化的方式即可。
開始之前,需要克隆儲存庫:
git clone https://github.com/ruby/ruby
與實際使用的大多數儲存庫相比,該儲存庫的最大不同之處在於它沒有分支,但是它有很多標籤,它們與分支相似,因為它們都只是指向一個提交的指標而已。因此,我們將使用標籤而不是分支進行練習。改變標籤的方式和分支非常不同,但檢視標籤和分支的方式完全相同。
執行這些練習時要記住的最重要的一點是,如本頁面所述,像9e3d9a2a009d2a0281802a84e1c5cc1c887edc71
這樣的 Git SHA 始終參照同一個的程式碼。下圖摘自我與凱蒂·西勒·米勒撰寫的一本雜誌,名為《Oh shit, git!》。(她還有一個名為 https://ohshitgit.com/ 的很棒的網站,啟發了該雜誌。)
我們將在練習中大量使用 Git SHA,以使你習慣於使用它們,並幫助你了解它們與標籤和分支的對應關係。
所有這些練習僅使用這 5 個 Git 子命令:
git checkoutgit log (--oneline, --author, and -S will be useful)git diff (--stat will be useful)git showgit status
3db12e8b236ac8f88db8eb4690d10e4a3b8dbcd4
。找出當時 Ruby 的程式碼行數。hash.c
的歷史記錄。更改該檔案的最後一個提交 ID 是什麼?hash.c
的變化:將 master 分支上的檔案與提交 3db12e8b236ac8f88db8eb4690d10e4a3b8dbcd4
的檔案進行比較。hash.c
的提交,並檢視該提交的差異。v1_8_6_187
和標籤 v1_8_6_188
之間更改了多少檔案。v1_8_6_187
對應的提交。.git/refs/tags
。執行 cat .git/refs/tags/v1_8_6_187
來檢視其中一個檔案的內容。HEAD
對應的提交 ID。test/
目錄進行了多少次提交。65a5162550f58047974793cdc8067a970b2435c0
和 9e3d9a2a009d2a0281802a84e1c5cc1c887edc71
之間的 lib/telnet.rb
的差異。該檔案更改了幾行?v2_5_1
和 v2_5_3
)(這一步有點棘手,步驟不只一步)e51dca2596db9567bd4d698b18b4d300575d3881
並建立一個指向該提交的新分支。git reflog
以檢視你到目前為止完成的所有儲存庫導航操作。 ——————————————————————————–