七個你無法忽視的Git使用技巧

jopen 9年前發布 | 24K 次閱讀 Git

</div>

程序開發中的版本控制必不可少,Python開發也一樣。而版本控制系統中,目前使用最廣泛的,可能就是Git,而它最著名的代表就是Github。本篇譯文為大家介紹了7個Git使用技巧,目的都是方便程序員彌補自己在開發中所犯的錯誤。

</blockquote>

與其他技術相比,Git應該拯救了更多開發人員的飯碗。只要你經常使用Git保存自己的工作,你就一直有機會可以將代碼退回到之前的狀態,因此就可以挽回那些你深夜里迷迷糊糊犯下的錯誤。

盡管這么說,Git的命令行界面可是出了名的難掌握。接下來,就給大家介紹7個小技巧,最大限度發揮Git的作用。

photo credit: xkcd

通常,大部分時間我們都只會用到addcommit、branch和push/pull這些命令。大部分人熟悉這套只往一個方向運轉的工作流。你們有沒有想過,如果自己往倉庫中添加了錯誤的文件,或是將代碼提交到了錯誤的分支,而且提交信息還寫錯了的話,自己怎樣才能取消之前的操作?如果你也是按照上面漫畫中所描繪的一樣操作的(即刪除本地項目文件夾,再重新下載倉庫),那么你就有必要了解下面這些Git使用技巧了。

1. 修改錯誤的提交信息(commit message)

提交信息很長時間內會一直保留在你的代碼庫(code base)中,所以你肯定希望通過這個信息正確地了解代碼修改情況。下面這個命令可以讓你編輯最近一次的提交信息,但是你必須確保沒有對當前的代碼庫(working copy)做修改,否則這些修改也會隨之一起提交。

$ git commit --amend -m ”YOUR-NEW-COMMIT-MESSAGE”

假如你已經將代碼提交(git commit)推送(git push)到了遠程分支,那么你需要通過下面的命令強制推送這次的代碼提交。

$ git push <remote> <branch> --force

你可以關注Stack Overflow網站上的這條問答, 獲取更多詳情。

2. 提交之前撤銷git add

如果你往暫存區(staging area)中加入了一些錯誤的文件,但是還沒有提交代碼。你可以使用一條簡單的命令就可以撤銷。如果只需要移除一個文件,那么請輸入:

$ git reset <文件名>

或者如果你想從暫存區移除所有沒有提交的修改:

$ git reset

你可以關注Stack Overflow網站上的這條問答, 獲取更多詳情。

3. 撤銷最近一次代碼提交

有時候你可能會不小心提交了錯誤的文件或一開始就遺漏了某些東西。下面這三步操作可以幫助你解決這個問題。

$ git reset --soft HEAD~1 # 對工作文件進行必要的更改 $ git add -A . $ git commit -c ORIG_HEAD

你執行第一個命令時,Git會將HEAD指針(pointer)后移到此前的一次提交,之后你才能移動文件或作必要的修改。

然后你就可以添加所有的修改,而且當你執行最后的命令時,Git會打開你的默認文本編輯器,其中會包含上一次提交時的信息。如果愿意的話,你可以修改提交信息,或者你也可以在最后的命令中使用-C而不是-c,來跳過這一步。

4. Git倉庫撤銷至前一次提交時的狀態

“撤銷”(revert)在許多情況下是非常有必要的——尤其是你把代碼搞的一團糟的情況下。最常見的情況是,你想回到之前代碼版本,檢查下那個時候的代碼庫,然后再回到現在狀態。這可以通過下面的命令實現:

$ git checkout <SHA>

“”是你想查看的提交擁有的哈希值(Hash Code)中前8至10個字符。 這個命令會使<HEAD>指針脫離(detach),可以讓你在不檢出(check out)任何分支的情況下查看代碼——脫離HEAD并不像聽上去那么可怕。如果你想在這種情況下提交修改,你可以通過創建新的分支來實現:

$ git checkout -b <SHA>

要想回到當前的工作進度,只需要檢出(check out)你之前所在的分支即可。

你可以關注Stack Overflow網站上的這條問答, 獲取更多詳情。

5. 撤銷合并(Merge)

要想撤銷合并,你可能必須要使用恢復命令(HARD RESET)回到上一次提交的狀態。“合并”所做的工作基本上就是重置索引,更新working tree(工作樹)中的不同文件,即當前提交()代碼中與HEAD游標所指向代碼之間的不同文件;但是合并會保留索引與working tree之間的差異部分(例如那些沒有被追蹤的修改)。

$ git checkout -b <SHA>

當然,Git中總是有其他的實現辦法,你可以查看看這篇文章繼續了解。

6. 從當前Git分支移除未追蹤的本地文件

假設你湊巧有一些未被追蹤的文件(因為不再需要它們),不想每次使用git status命令時讓它們顯示出來。下面是解決這個問題的一些方法:

$ git clean -f -n # 1 $ git clean -f # 2 $ git clean -fd # 3 $ git clean -fX # 4 $ git clean -fx # 5 

  • (1): 選項-n將顯示執行(2)時將會移除哪些文件。
  • (2): 該命令會移除所有命令(1)中顯示的文件。
  • (3): 如果你還想移除文件件,請使用選項-d。
  • (4): 如果你只想移除已被忽略的文件,請使用選項-X。
  • (5): 如果你想移除已被忽略和未被忽略的文件,請使用選項-x。
  • </ul>

    請注意最后兩個命令中X的區別。

    更多詳情,請查看官方文檔中關于git-clean的介紹

    Photo credit: xkcd

    7. 刪除本地和遠程Git分支

    刪除本地分支:

    $ git branch --delete --force <branchName>

    或者使用選項-D作為簡寫:

    $ git branch -D

    刪除遠程分支:

    $ git push origin --delete <branchName>

    建議:要想更好地掌握Git的用法,請仔細閱讀Git官方文檔。

    來自:http://codingpy.com/article/seven-git-hacks-you-just-cannot-ignore/

     本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
     轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
     本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!