首頁  >  文章  >  web前端  >  你真的了解Git嗎?

你真的了解Git嗎?

DDD
DDD原創
2024-09-25 06:29:31247瀏覽

Do you really know Git?

本部落格中的圖片來自 Scott Chacon、Ben Straub 的「Pro Git」

在這個部落格中,您將了解有關您在程式設計中使用的 Git 中的一些日常功能的各種精彩事實!

開發人員很容易盲目使用工具而不知道它們在幕後是如何工作的。雖然這種抽像是為了更好,但了解事物如何運作有時可能是經驗豐富的程式設計師和業餘程式設計師之間的區別。

讓我們深入了解一些很酷的事實!


1 - 短期狀態

如果您已經使用 Git 相當長一段時間,您應該了解 git status。但是,您是否知道有一個選項可以獲得更具可讀性和最小化的狀態輸出?

透過使用短狀態標誌 -s,您可以獲得更緊湊的格式。

$ git status -s
 M README
MM Rakefile
A  lib/git.rb
M  lib/simplegit.rb
?? LICENSE.txt

您會注意到輸出的左側部分有 2 列。左列代表暫存區的狀態,右列代表工作樹的狀態。動作順序也按時間順序從左到右表示。

讓我們解釋一下上面的輸出:

  • 「M」 - 修改但未上演
  • 「MM」 - 上演後再修改。因此,下一次提交需要一個額外的階段。
  • 「A」 - 建立並暫存一個新檔案
  • 「M」 - 上演
  • 「??」 - 建立了一個新文件,但未暫存(未追蹤)

2 - 跳過暫存區

如果您想暫存追蹤的 檔案並在一個命令中提交所有內容,該怎麼辦?

您可以使用git commit -a -m "message"

請注意,不幸的是,未追蹤的檔案(新建立的檔案)將不會使用這個神奇的命令進行暫存。


3 - 查看您的提交歷史記錄

使用 git log 按時間倒序列出儲存庫中所做的提交(最近的提交首先顯示)。

有多種選項可讓您自訂輸出。讓我們回顧一些有用的:

  • -{number} 限制顯示的日誌條目數(例如,git log -2 顯示最後兩個項目)
  • --stat 顯示縮寫統計訊息,例如每次提交的文件數或插入/刪除數
  • --pretty=oneline 將每個提交印在一行上
  • --graph 新增一個 ASCII 圖表,顯示您的分支和合併歷史記錄

4 - 使用 Git Restore 撤銷操作

當您想要取消暫存檔案時,請使用git reset HEAD 。當您想要取消修改已修改的檔案時,請使用 git checkout -- {file}

現在有一個更簡單的方法可以做到這兩點! Git 版本 2.23.0 引入了 git Restore,它帶來了取消暫存和取消修改檔案的二合一功能。

  • git Restore {file} - 取消修改已修改的檔案
  • git Restore --staged {file} - 取消暫存檔案

5 - Git Fetch 與 Git Pull

身為程式設計師,您很可能至少使用過 git pull 一次。此外,您很可能聽說過 git fetch 但從未真正需要使用它。好吧,讓我們來談談它實際上做了什麼以及它與 git pull 有何不同。

您可以將 fetch 視為 pull 中發生的事情的第一步。

在拉取中,我們從遠端儲存庫下載所有資料並將其傳輸到本機儲存庫。這就是 fetch 的作用。

此時,您的本機儲存庫已擁有數據,但尚未將其與工作目錄合併,以便您可以處理最新的變更。拉取的下一步是與您的分支合併,以便最新的變更位於您的工作目錄中。

因此,pull 一次取得並合併所有內容,而 fetch 只執行第一步。


6 - Git 別名

如果我告訴你有一個方法可以讓你的 git 指令可自訂怎麼辦?透過git config,你就可以!

您可以為常用指令設定別名,如下所示:

$ git config --global alias.co checkout
$ git config --global alias.br branch
$ git config --global alias.ci commit
$ git config --global alias.st status

現在,您不需要輸入 git commit,只需輸入 git ci.

這對於幫助使特定任務更加直觀的命令特別有用。

$ git config --global alias.unstage 'reset HEAD --'
# the double dash serves as an option separator. 
# It tells Git to treat anything after it as a filename

上面的指令使以下指令等效:

  • git unstage fileA
  • git reset HEAD -- fileA

It's also common to add a last command to see your most recent commit:

$ git config --global alias.last 'log -1 HEAD'

That's all for this blog! I hope you learned a few neat tricks for your next project with Git that will improve the quality of your workflow. Thanks for reading!

以上是你真的了解Git嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn