0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

7個實用的Git 小技巧

Linux愛好者 ? 來源:Linux中國 ? 作者:Rajeev Bera ? 2021-07-29 10:22 ? 次閱讀

這些有用的小技巧將改變你在當前最流行的版本控制系統(tǒng)下的工作方式。

Git 是當前最流行最普遍的版本控制系統(tǒng)之一,它被應用于私有系統(tǒng)和公開網(wǎng)站上各種各樣的開發(fā)工作。不論我變得對 Git 有多熟悉,似乎總有些功能等待著被發(fā)掘。下面分享下和 Git 相關的改變我工作方式的一些小技巧。

1、Git 中的自動糾錯

我們每個人都不時在輸入時犯拼寫錯誤,但是如果你使能了 Git 的自動糾錯功能,你就能讓 Git 自動糾正一些輸入錯誤的子命令。

假如你想用命令 git status 來檢查狀態(tài),但是你恰巧錯誤地輸入了 git stats。通常情況下,Git 會告訴你 ‘stats’ 不是個有效的命令:

$ git statsgit: ‘stats’ is not a git command. See ‘git --help’.The most similar command isstatus

為了避免類似情形,只需要在你的 Git 配置中使能自動糾錯功能。

$ git config --global help.autocorrect 1

如果你只想對當前的倉庫生效,就省略掉選項 --global。

這個命令會使能自動糾錯功能。在相應的 Git 官方文檔[1] 中可以看到這個命令的詳細說明,但是試著敲一下上面的錯誤命令會使你對這個設置干了什么有個直觀的了解:

$ git statsgit: ‘stats’ is not a git command. See ‘git --help’.On branch masterYour branch is up to date with ‘origin/master’.nothing to commit, working tree clean

在上面的例子中,Git 直接運行了它建議命令的第一個,也就是 git status,而不是給你展示它所建議的子命令。

2、對提交進行計數(shù)

需要對提交進行計數(shù)的原因有很多。例如,一些開發(fā)人員利用提交計數(shù)來判斷什么時候遞增工程構建序號,也有一些開發(fā)人員用提交計數(shù)來對項目進展取得一個整體上的感觀。

對提交進行計數(shù)相當簡單而且直接,下面就是相應的 Git 命令:

$ git rev-list --count branch-name

在上述命令中,參數(shù) branch-name 必須是一個你當前倉庫里的有效分支名。

$ git rev-list –count master32$ git rev-list –count dev34

3、倉庫優(yōu)化

你的代碼倉庫不僅對你來說很寶貴,對你所在的組織也一樣。通過少數(shù)幾個慣例你就能使自己的倉庫整潔并且保持最新。使用 .gitignore 文件[2] 就是這些最好的慣例之一。通過使用這個文件你可以告訴 Git 不要保存一些不需要記錄的文件,如二進制文件、臨時文件等等。

當然,你還可以使用 Git 的垃圾回收來進一步優(yōu)化你的倉庫。

$ git gc --prune=now --aggressive

這個命令在你和你的團隊經(jīng)常使用 pull 或者 push 操作的時候很有幫助。

它是一個內部工具,能清理掉你的倉庫里沒法訪問或者說“空懸”的 Git 對象。

4、給未追蹤的文件來個備份

大多數(shù)時候,刪除所有未追蹤的文件是安全的。但很多時候也有這么一種場景,你想刪掉這些未追蹤的文件同時也想做個備份防止以后需要用到。

Git 組合一些 Bash 命令和管道操作,可以讓你可以很容易地給那些未追蹤的文件創(chuàng)建 zip 壓縮包。

$ git ls-files --others --exclude-standard -z | xargs -0 tar rvf ~/backup-untracked.zip

上面的命令就生成了一個名字為 backup-untracked.zip 的壓縮包文件(當然,在 .gitignore 里面忽略了的文件不會包含在內)。

5、了解你的 .git 文件夾

每個倉庫都有一個 .git 文件夾,它是一個特殊的隱藏文件夾。

$ ls -a. … .git

Git 主要通過兩個東西來工作:

當前工作樹(你當前檢出的文件狀態(tài))

你的 Git 倉庫的文件夾(準確地說,包含版本信息的 .git 文件夾的位置)

這個文件夾存儲了所有參考信息和一些其他的如配置、倉庫數(shù)據(jù)、HEAD 狀態(tài)、日志等更多諸如此類的重要細節(jié)。

一旦你刪除了這個文件夾,盡管你的源碼沒被刪,但是類似你的工程歷史記錄等遠程信息就沒有了。刪除這個文件夾意味著你的工程(至少本地的復制)不再在版本控制的范疇之內了。這也就意味著你沒法追蹤你的修改;你沒法從遠程倉拉取或推送到遠程倉了。

通常而言,你需要或者應當對你的 .git 文件夾的操作并不多。它是被 Git 管理的,而且大多數(shù)時候是一個禁區(qū)。然而,在這個文件夾內還是有一些有趣的工件,比如說當前的 HEAD 狀態(tài)在內的就在其中。

$ cat .git/HEADref: refs/heads/master

它也隱含著對你倉庫地描述:

$ cat .git/description

這是一個未命名的倉庫;通過編輯文件 ‘description’ 可以給這個倉庫命名。

Git 鉤子文件夾連同一些鉤子文件例子也在這里。參考這些例子你就能知道 Git 鉤子能干什么了。當然,你也可以 參考這個 Seth Kenlon 寫的 Git 鉤子介紹[3]。

6、瀏覽另一個分支的文件

有時,你會想要瀏覽另一個分支下某個文件的內容。這其實用一個簡單的 Git 命令就可以實現(xiàn),甚至都不用切換分支。

設想你有一個命名為 README.md[4] 的文件,并且它在 main 分支上。當前你正工作在一個名為 dev 的分支。

用下面的 Git 命令,在終端上就行。

$ git show main:README.md

一旦你執(zhí)行這個命令,你就能在你的終端上看到 main 分支上該文件的內容。

7、Git 中的搜索

用一個簡單的命令你就能在 Git 中像專業(yè)人士一樣搜索了。更有甚者,盡管你不確定你的修改在哪次提交或者哪個分支上,你依然能搜索。

$ git rev-list --all | xargs git grep -F ‘’

例如,假設你想在你的倉庫中搜索字符串 “font-size: 52 px;“ :

$ git rev-list –all | xargs git grep -F ‘font-size: 52 px;’F3022…9e12:HtmlTemplate/style.css: font-size: 52 px;E9211…8244:RR.Web/Content/style/style.css: font-size: 52 px;

試試這些小技巧

我希望這些小技巧對你是有用的,或者增加你的生產(chǎn)力或者節(jié)省你的大量時間。

你也有一些喜歡的 Git 技巧嗎?在評論區(qū)分享吧。

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Git
    Git
    +關注

    關注

    0

    文章

    195

    瀏覽量

    15712

原文標題:7 個改變我生活的 Git 小技巧

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    打開esp-idf的任意一component時,vscode會自動導入該component的git倉庫,怎么解決?

    當我打開esp-idf 的任意一component時,vscode會自動導入該component的git倉庫,導致vscode的源碼管理非常擁擠,請問這有什么辦法解決嗎?還是我vscode設置不對導致? 希望大家能指導指導,感謝!
    發(fā)表于 06-21 07:39

    ubuntu下的vscode插件安裝idf時,總是找不到git,為什么?

    總是提示:Git is not found in current environment 但是我已經(jīng)在setting.json下設置了\"git.path\": \"/bin/git\" 同行,命令行里查看
    發(fā)表于 06-21 07:16

    Git發(fā)布新版本 修補五處安全漏洞 包含嚴重遠程代碼執(zhí)行風險

    CVE-2024-32002漏洞的嚴重性在于,黑客可通過創(chuàng)建特定的Git倉庫子模塊,誘騙Git將文件寫入.git/目錄,而非子模塊的工作樹。如此一來,攻擊者便能在克隆過程中植入惡意腳本,用戶幾乎無法察覺。
    的頭像 發(fā)表于 05-31 10:09 ?517次閱讀

    飛凌ElfBoard ELF 1板卡-ubuntu18.04 git安裝及基本使用

    git commit -m xxx(xxx代表備注信息) 6.查看提交記錄git log 7.查看分支git branch 添加新的分支git
    發(fā)表于 03-21 16:23

    藍牙 | 軟件:Git管理高通的ChipCode項目

    最近發(fā)現(xiàn)大家在高通chipcode網(wǎng)站上下載不了代碼,小編一直使用git的方式獲取新版本代碼,沒有遇到什么阻礙。于是小編到新主機上嘗試下載代碼的壓縮包和git代碼,都遇到了問題。由于壓縮包是高通自己
    的頭像 發(fā)表于 01-26 08:29 ?335次閱讀
    藍牙 | 軟件:<b class='flag-5'>Git</b>管理高通的ChipCode項目

    克服PLC編程的難題—基于Git的軟件

    Git是一種分布式版本控制系統(tǒng),它可以記錄文件的修改歷史和版本變化,并可以支持多人協(xié)同開發(fā)。
    的頭像 發(fā)表于 01-22 09:30 ?891次閱讀
    克服PLC編程的難題—基于<b class='flag-5'>Git</b>的軟件

    Git開發(fā)者關注內存安全問題,探討引入Rust語言

    根據(jù)最新披露的郵件討論,Git開發(fā)團隊熱議在Git項目中引入Rust的可行性。作為一種開源的分布式代碼版本管理工具,廣泛運用于各種開發(fā)項目。盡管現(xiàn)在Git項目主要以C與Python為主要開發(fā)語言,但探討顯示,引入Rust能顯著降
    的頭像 發(fā)表于 01-15 14:23 ?524次閱讀
    <b class='flag-5'>Git</b>開發(fā)者關注內存安全問題,探討引入Rust語言

    GIT(分布式版本控制系統(tǒng))的工作原理

    都是完整的,功能更強大,自然而然操作更復雜一些。git在本地也是以git版本庫的形式管理,可以在本地做一些修改,然后commit到本地的版本庫,最后push到服務器。
    的頭像 發(fā)表于 12-21 16:09 ?754次閱讀
    <b class='flag-5'>GIT</b>(分布式版本控制系統(tǒng))的工作原理

    Git命令解決常見場景記錄

    本文主要歸納一下git的學習記錄,在開發(fā)期間發(fā)現(xiàn)了git在sourcetree的處理不是很好,對于多選文件的丟棄這點不是很方便,所以做一記錄,由于項目中有新建的文件,所以被識別為未跟蹤的文件,但我
    的頭像 發(fā)表于 12-20 09:44 ?385次閱讀
    用<b class='flag-5'>Git</b>命令解決常見場景記錄

    git切換遠程地址分支方式

    git remote set-url origin URL】 更換遠程倉庫地址,URL為新地址。
    的頭像 發(fā)表于 12-18 09:35 ?2074次閱讀

    Git命令之本地分支與遠程分支關聯(lián)和解除

    的遠程分支被刪除了,那么就會出現(xiàn)你無法使用git pull,和git push命令。使用一例子說明這個場景。 我們可以使用下面的命令查看自己本地分支與與遠程分支的關聯(lián)情況。
    的頭像 發(fā)表于 12-15 09:27 ?2718次閱讀
    <b class='flag-5'>Git</b>命令之本地分支與遠程分支關聯(lián)和解除

    git命令的基本使用

    git config 第一次使用git或者剛安裝的git時,使用此命令設置身份Name 和 Eamail 地址。并且每次提交時會使用此信息。
    的頭像 發(fā)表于 12-11 13:53 ?854次閱讀

    Mozilla Firefox開發(fā)將完全轉向Git,放棄Mercurial

    目前相關事項仍在規(guī)劃中,預計至少六月后才會開始全面的 Git 過渡。過渡完成后,Mercurial 將從 Firefox 開發(fā)工作流程中完全淘汰。
    的頭像 發(fā)表于 11-23 16:08 ?581次閱讀
    Mozilla Firefox開發(fā)將完全轉向<b class='flag-5'>Git</b>,放棄Mercurial

    Git是如何存儲文件的?Git的工作原理解析

    我以為我已經(jīng)對 Git 的工作方式了如指掌,但我以前從未真正涉及過打包文件,所以這次探索很有趣。我也很少思考當我讓 git log 跟蹤一文件的歷史時,它實際上有多大的工作量,因此也很開心能深入研究這個。
    的頭像 發(fā)表于 10-31 15:36 ?518次閱讀

    Git中最常用的命令介紹

    git add命令用于將修改的文件添加到下一次提交的暫存區(qū)。你可以指定要添加的文件git add命令用于將修改的文件添加到下一次提交的暫存區(qū)。你可以指定要添加的文件,例如git add file1.txt file2.txt。
    發(fā)表于 10-26 10:27 ?200次閱讀
    <b class='flag-5'>Git</b>中最常用的命令介紹