10 個迅速提升你 Git 水平的提示

oschina發表於2014-08-20

10 個迅速提升你 Git 水平的提示

 

轉載自開源中國社群http://www.oschina.net/translate/10-tips-git-next-level

1. Git自動補全

假使你使用命令列工具執行Git命令,那麼每次手動輸入各種命令是一件很令人厭煩的事情。
為了解決這個問題,你可以啟用Git的自動補全功能,完成這項工作僅需要幾分鐘。

為了得到這個指令碼,在Unix系統下執行以下命令:

 
  1. cd ~  
  2. curl https://raw.github.com/git/git/master/contrib/completion/git-completion.bash -o ~/.git-completion.bash  
然後,新增下面幾行到你的 ~/.bash_profile 檔案中:
 
  1. if [ -f ~/.git-completion.bash ]; then  
  2.     . ~/.git-completion.bash  
  3. fi  
儘管早些時候我們已經提到這個,但是強調的不夠充分。如果你想使用git的全部功能特性,
你絕對應該切換到命令列介面!
 

2. 在 Git 中忽略檔案

你是不是很煩那些編譯過的檔案 (比如 .pyc) 出現在你的 Git 倉庫中?或者說你已經受夠了已經把它們都加進了 Git 倉庫?好了,這有個辦法可以讓你告訴 Git 忽略掉那些特定的檔案和資料夾。只需要建立一個名為 .gitignore 然後列出那些你不希望 Git 跟蹤的檔案和資料夾。你還可以新增例外,通過使用感嘆號(!)。

 
  1. 2  
  2. 3  
  3. 4  
  4. 5  
  5.    
  6. *.pyc  
  7. *.exe  
  8. my_db_config/  
  9.    
  10. !main.pyc  
  11.    

3. 是誰弄亂了我的程式碼?

當事情出錯時,先去指責別人是人類的天性之一。如果你的產品伺服器掛了,使用git blame命令可以很容易找出罪魁禍首。這個命令可以將檔案中的每一行的作者、最新的變更提交和提交時間展示出來。

  1. git blame [file_name]  
 
在下面的截圖中你可以看到命令是如何在更大的目錄中搜尋。
 

4. 檢視倉庫歷史記錄

上一節我們已經學習瞭如何使用 git log ,不過,這裡還有三個你應該知道的選項。

  • --oneline- 壓縮模式,在每個提交的旁邊顯示經過精簡的提交雜湊碼和提交資訊,以一行顯示。

  • --graph- 圖形模式,使用該選項會在輸出的左邊繪製一張基於文字格式的歷史資訊表示圖。如果你檢視的是單個分支的歷史記錄的話,該選項無效。

  • --all- 顯示所有分支的歷史記錄

把這些選項組合起來之後,輸出看起來會像這樣:

5. 絕對不要丟失對Commit的跟蹤

假設你不小心提交了些你不想要的東西,不得不做一次強制重置來恢復到之前的狀態。然後,你意識到在這一過程中你丟失了其它一些資訊並且想要把它們找回來,或者至少瞅一眼。這正是git reflog可以做到的。

一個簡單的git log命令可以為你展示最後一次commit,以及它的父親,還有它父親的父親等等。而git reflog則列出了head曾經指向過的一系列commit。要明白它們只存在於你本機中;而不是你的版本倉庫的一部分,也不包含在push和merge操作中。

如果我執行git log命令,我可以看到一些commit,它們都是我倉庫的一部分:

然而,一個git reflog命令則展示了一次commit (b1b0ee9–HEAD@{4}),它正是我剛才進行強制重置時弄丟的:

6. 暫存檔案的部分改動

一般情況下,建立一個基於特性的提交是比較好的做法,意思是每次提交都必須代表一個新特性的產生或者是一個bug的修復。如果你修復了兩個bug,或是新增了多個新特性但是卻沒有提交這些變化會怎樣呢?在這種情況下,你可以把這些變化放在一次提交中。但更好的方法是把檔案暫存(Stage)然後分別提交。

例如你對一個檔案進行了多次修改並且想把他們分別提交。這種情況下,你可以在 add 命令中加上 -p 引數

  1. git add -p [file_name]  

我們來演示一下在 file_name 檔案中新增了3行文字,但只想提交第一行和第三行。先看一下 git diff 顯示的結果:

然後再看看在 add 命令中新增 -p 引數是怎樣的?

看上去,Git 假定所有的改變都是針對同一件事情的,因此它把這些都放在了一個塊裡。你有如下幾個選項:

  • 輸入 y 來暫存該塊

  • 輸入 n 不暫存

  • 輸入 e 手工編輯該塊

  • 輸入 d 退出或者轉到下一個檔案

  • 輸入 s 來分割該塊

在我們這個例子中,最終是希望分割成更小的部分,然後有選擇的新增或者忽略其中一部分。

正如你所看到的,我們新增了第一行和第三行而忽略了第二行。之後你可以檢視倉庫狀態之後並進行提交。

7. 壓縮多個Commit

當你提交程式碼進行程式碼審查時或者建立一次pull request (這在開源專案中經常發生),你的程式碼在被接受之前會被要求做一些變更。於是你進行了變更,並且直到下一次審查之前你沒有再次被要求進行變更過。在你知道又要進行變更之前,你已經有了一些額外的commit。理想情況下,你可以用rebase命令把多個commit壓縮成一個。

 
  1. git rebase -i HEAD~[number_of_commits]  

如果你想要壓縮最後兩個commit,你需要執行下列命令。

 
  1. git rebase -i HEAD~2  

執行該命令時,你會看到一個互動介面,列出了許多commit讓你選擇哪些需要進行壓縮。理想情況下,你選擇最後一次commit並把其它老commit都進行壓縮。

然後會要求你為新的commit錄入提交資訊。這一過程本質上重寫了你的commit歷史。

8. Stash未提交的更改

你正在修改某個bug或者某個特性,又突然被要求展示你的工作。而你現在所做的工作還不足以提交,這個階段你還無法進行展示(不能回到更改之前)。在這種情況下, git stash可以幫助你。stash在本質上會取走所有的變更並儲存它們為以備將來使用。stash你的變更,你只需簡單地執行下面的命令-

 
  1. git stash  

希望檢查stash列表,你可以執行下面的命令:

 
  1. git stash list  

如果你想要解除stash並且恢復未提交的變更,你可以進行apply stash:

 
  1. git stash apply  

在螢幕截圖中,你可以看到每個stash都有一個識別符號,一個唯一的號碼(儘管在這種情況下我們只有一個stash)。如果你只想留有餘地進行apply stash,你應該給apply新增特定的識別符號:

 
  1. git stash apply stash@{2}  

9.檢查丟失的提交

儘管 reflog 是唯一檢查丟失提交的方式。但它不是適應用於大型的倉庫。那就是 fsck(檔案系統檢測)命令登場的時候了。

  1. git fsck --lost-found  

這裡你可以看到丟掉的提交。你可以通過執行 git show [commit_hash] 檢視提交之後的改變或者執行git merge [commit_hash] 來恢復到之前的提交。

git fsck 相對reflog是有優勢的。比方說你刪除一個遠端的分支然後關閉倉庫。 用fsck 你可以搜尋和恢復已刪除的遠端分支。

10. Cherry Pick

我把最優雅的Git命令留到了最後。cherry-pick命令是我目前為止最喜歡的git命令,既是因為它的字面意思,也因為它的功能。

簡而言之,cherry-pick就是從不同的分支中撿出一個單獨的commit,並把它和你當前的分支合併。如果你以並行方式在處理兩個或以上分支,你可能會發現一個在全部分支中都有的bug。如果你在一個分支中解決了它,你可以使用cherry-pick命令把它commit到其它分支上去,而不會弄亂其他的檔案或commit。

讓我們來設想一個用得著它的場景。我現在有兩個分支,並且我想cherry-pick b20fd14: Cleaned junk 這個commit到另一個上面去。

我切換到想被cherry-pick應用到的這個分支上去,然後執行了如下命令:

  1. git cherry-pick [commit_hash]  

 

儘管我們這次完成了一次乾淨的cherry-pick,你也應該意識到這個命令可能會產生衝突。所以用它時請無比小心。

總結

說著說著就到了文章的最後,我認為這些技巧會讓你的 Git 水平提升到一個新的高度。Git 是最棒的,它幾乎能實現你所能想到的事情。因此,要經常挑戰自己的Git水平。最後你很有可能會學到新的東西。

 

相關文章