衡阳派盒市场营销有限公司

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

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

3天內不再提示

第一本Git命令教程(7.1)-清理之緩存

454398 ? 來源:alpha007 ? 作者:alpha007 ? 2022-12-05 17:39 ? 次閱讀

今天是 Git 系列課程第七課,上一課我們學會了查看 Git 本地歷史提交,今天痞子衡要講的是 Git 倉庫的清理操作,一共 4 個命令,都是日常開發中非常實用的命令,掌握這 4 個命令,會讓你有一種玩弄 Git 倉庫于股掌的感覺。

由于本節課是教程的核心課程,所以會分 4 小節課來講,第一講介紹 git stash

1. 緩存文件改動 git stash

試想一下你在使用 Git 時有沒有這樣的經歷,你正在寫代碼(修改文件),但是代碼還沒有寫完善,沒達到提交的標準,但是你知道了有另一個 team member 推送了一個提交,這個提交你需要立刻同步到你的本地,此時怎么辦?是的,你需要本地緩存你的改動。

1.1 緩存當前改動 git stash [save -a "description"]

// 在 test.c 文件里增加一個 test_stash0()函數 jay@pc MINGW64 /d/my_project/gittest (master)$ git diff app/test.c

diff --git a/app/test.c b/app/test.c
index 70dde01..38b763c 100644
--- a/app/test.c
+++ b/app/test.c
@@ -1,5 +1,8 @@
 #include 
 #include 
+void test_stash0(void)
+{
+}
 void test(void)
 {
     printf("this is test/n");

// 將增加 test_stash0()函數的改動緩存起來 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash save -a "add test_stash0()"

Saved working directory and index state On master: add test_stash0()

// 緩存之后查看 Git 空間很干凈,說明緩存成功 jay@pc MINGW64 /d/my_project/gittest (master)$ git status

On branch master
Your branch is ahead of 'origin/master' by 2 commits.
  (use "git push" to publish your local commits)

nothing to commit, working tree clean

// 在 test.c 文件里再依次 test_stash1()、test_stash2()函數,并依次緩存 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash save -a "add test_stash1()"

Saved working directory and index state On master: add test_stash1()

jay@pc MINGW64 /d/my_project/gittest (master)$ git stash save -a "add test_stash2()"

Saved working directory and index state On master: add test_stash2()

1.2 查看所有已緩存改動列表 git stash list

// 查看緩存 list,此時顯示共有三次緩存 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash list

stash@{0}: On master: add test_stash2()
stash@{1}: On master: add test_stash1()
stash@{2}: On master: add test_stash0()

1.3 查看某個已緩存改動的具體細節 git stash show -p [stash@{n}]

// 查看編號為 stash@{1} 的緩存的具體改動 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash show -p stash@{1}

diff --git a/app/test.c b/app/test.c
index 70dde01..4380571 100644
--- a/app/test.c
+++ b/app/test.c
@@ -1,5 +1,8 @@
 #include 
 #include 
+void test_stash1(void)
+{
+}
 void test(void)
 {
     printf("this is test/n");

1.4 恢復某個已緩存改動 git stash pop [stash@{n}]

現在我們需要從緩存區恢復某個已緩存改動,可以直接用 git stash pop 恢復最近的一次緩存,也可以用 git stash pop stash@{n} 恢復任意指定的一次緩存(也可以用 git stash pop apply stash@{n} 來恢復某個緩存,但是 apply 命令并不會將被恢復的緩存改動從緩存區 list 里刪除)

// 將編號為 stash@{1} 的緩存恢復 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash pop stash@{1}

On branch master
Your branch is ahead of 'origin/master' by 2 commits.
  (use "git push" to publish your local commits)

Changes not staged for commit:
  (use "git add ..." to update what will be committed)
  (use "git checkout -- ..." to discard changes in working directory)

        modified:   app/test.c

no changes added to commit (use "git add" and/or "git commit -a")
Dropped stash@{1} (62daecdc826586bb3c0cbe93c5f8d2e2697e9ea)

// 查看原編號為 stash@{1} 的緩存的具體改動,確實已正常恢復 jay@pc MINGW64 /d/my_project/gittest (master)$ git diff app/test.c

diff --git a/app/test.c b/app/test.c
index 70dde01..38b763c 100644
--- a/app/test.c
+++ b/app/test.c
@@ -1,5 +1,8 @@
 #include 
 #include 
+void test_stash0(void)
+{
+}
 void test(void)
 {
     printf("this is test/n");

// 查看緩存 list 里被恢復的緩存"add test_stash1()"(原編號 stash@{1} 已被釋放)已不在 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash list

stash@{0}: On master: add test_stash2()
stash@{1}: On master: add test_stash0()

1.5 丟棄某個已緩存改動 git stash drop [stash@{n}]

// 從緩存 list 里直接刪除編號為 stash@{1} 的緩存 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash drop stash@{1}

Dropped stash@{1} (2f5dd9a45f77bcb24cac247b8f88bdec157798f2)

// 查看緩存 list 里被刪除的緩存"add test_stash0()"(原編號 stash@{1} 已被釋放)已不在 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash list

stash@{0}: On master: add test_stash2()

1.6 清空所有已緩存改動 git stash clear

// 清空緩存 list jay@pc MINGW64 /d/my_project/gittest (master)$ git stash clear

// 查看緩存 list,其已被清空 jay@pc MINGW64 /d/my_project/gittest (master)$ git stash list


審核編輯黃昊宇

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

    關注

    0

    文章

    201

    瀏覽量

    15819
收藏 人收藏

    評論

    相關推薦

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-移植前準備git管理內核源碼

    我們前邊已經介紹過Git工具,是個非常實用的代碼管理工具。如果驗證編譯出的內核能夠正常啟動,就可以將源碼用git工具管理起來。可以清楚的了解源碼改動記錄。如果不小心把源碼改亂了還可以進行版本
    發表于 01-23 10:51

    飛凌嵌入式ElfBoard ELF 1板卡-移植前準備git管理內核源碼

    我們前邊已經介紹過Git工具,是個非常實用的代碼管理工具。如果驗證編譯出的內核能夠正常啟動,就可以將源碼用git工具管理起來。可以清楚的了解源碼改動記錄。如果不小心把源碼改亂了還可以進行版本
    發表于 01-22 10:39

    飛凌嵌入式ElfBoard ELF 1板卡-git管理源碼git安裝和使用

    第一種當前代碼的管理。Ubuntu上安裝git執行sudo apt-get install git 進行git安裝elf@ubuntu:~/work/example/hello$ su
    發表于 01-14 09:08

    HTTP緩存頭的使用 本地緩存與遠程緩存的區別

    HTTP緩存頭是組HTTP響應頭,它們控制瀏覽器和中間代理服務器如何緩存網頁內容。合理使用HTTP緩存頭可以顯著提高網站的加載速度和性能,減少服務器的負載。 1. HTTP
    的頭像 發表于 12-18 09:41 ?177次閱讀

    ROSCon China 2024 | RDK第一本教材來了!地瓜機器人與古月居發布新書《ROS 2智能機器人開發實踐》

    12月7日-8日,為期兩天的ROSCon China 2024在上海圓滿落幕,來自全球的ROS專家學者、開發者、企業代表齊聚堂,共享機器人前沿技術成果。地瓜機器人攜手眾多RDK生態產品亮相,并聯手古月居共同推出首基于RDK機器人開發者套件的教材——《ROS 2智能機器
    的頭像 發表于 12-10 18:48 ?541次閱讀
    ROSCon China 2024 | RDK<b class='flag-5'>第一本</b>教材來了!地瓜機器人與古月居發布新書《ROS 2智能機器人開發實踐》

    ROSCon China 2024 | RDK第一本教材來了!地瓜機器人與古月居發布新書《ROS 2智能機器人開發實踐》

    12月7日-8日,為期兩天的ROSCon China 2024在上海圓滿落幕,來自全球的ROS專家學者、開發者、企業代表齊聚堂,共享機器人前沿技術成果。地瓜機器人攜手眾多RDK生態產品亮相,并聯
    發表于 12-10 10:56 ?279次閱讀

    緩存美——如何選擇合適的本地緩存

    Guava cache是Google開發的Guava工具包中套完善的JVM本地緩存框架,底層實現的數據結構類似于ConcurrentHashMap,但是進行了更多的能力拓展,包括緩存過期時間設置、
    的頭像 發表于 11-17 14:24 ?417次閱讀
    <b class='flag-5'>緩存</b><b class='flag-5'>之</b>美——如何選擇合適的本地<b class='flag-5'>緩存</b>?

    ESP8266緩存AP后,是否會自動連接到任何緩存的AP?

    ,如果 ESP 進入范圍,ESP 是否會自動連接到任何緩存的 AP?還是只有第一個(或第零個)?我的任務是在它們之間切換嗎? SDK 說道
    發表于 07-11 07:58

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

    總是提示:Git is not found in current environment 但是我已經在setting.json下設置了\"git.path\": \"/bin/git\" 同行,
    發表于 06-21 07:16

    關于Docker 的清理命令集錦

    這篇文章主要介紹了Docker 清理命令集錦,需要的朋友可以參考下 復制代碼代碼如下: docker kill $(docker ps -a -q) ?刪除所有已經停止的容器 復制代碼代碼如下
    的頭像 發表于 06-13 15:56 ?435次閱讀

    通過git命令獲取ESP8266_RTOS_SDK失敗如何解決?

    本人使用的硬件平臺為esp8266,開發環境為ubuntu22.04。在通過git命令獲取ESP8266_RTOS_SDK失敗,通過上網搜索嘗試了很多方法無效。具體情況如下
    發表于 06-07 07:26

    bluenrg緩存不夠報錯怎么解決?

    有沒有人用過st的藍牙芯片啊?感覺太不好了,FAE也不給力,藍牙與手機連接后會斷開,數據在上傳時因為ble buffer緩存不夠也會報錯,然后斷開連接,問FAE為什么修改連接間隔第一次能得到響應,第二次需要等比較久的問題也沒得到回復
    發表于 05-13 09:02

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

    的名字\"git config --global user.email \"你的郵箱地址\" 4.把所有文件添加到緩存git add . 5.提交緩存區的所有修改到倉庫
    發表于 03-21 16:23

    全志D1s裸機開發體驗第一個程序

    體驗第一個程序 2.1 編譯燒錄運行 2.1.1編譯 先進入源碼目錄,打開 Git Bash,如下圖操作: 然后在 Git Bash 中執行 make 命令,可以生成
    發表于 03-08 11:43

    如何清理完arcgis殘留文件

    清理完ArcGIS殘留文件是個相對復雜的過程,需要逐個清理相關的文件和注冊表項。下面介紹如何清理完ArcGIS殘留文件。 步驟:準備工作
    的頭像 發表于 02-25 13:59 ?4954次閱讀
    百家乐游戏开发软件| 百家乐官网国际娱乐场| 大发888资讯网net| 百家乐官网代理合作| 临安市| 新世百家乐的玩法技巧和规则 | 百家乐官网长路投注法| 威尼斯人娱乐场wnsrdcylcbywz| 属龙人与属虎人做生意| 百家乐官网庄闲最佳打法| 郑州水果机遥控器| 百家乐娱乐求指点呀| 百家乐官网娱乐网送68元| 利高国际网上娱乐| 黄金城百家乐下载| 做生意挂什么画招财| 银河国际娱乐| 反赌百家乐的玩法技巧和规则 | 波音百家乐官网现金网投注平台排名导航 | 皇冠现金网网址| 高档百家乐桌子| 金满堂百家乐官网的玩法技巧和规则 | 欢乐谷娱乐城开户| 东营区百家乐艺术团| 凱旋門百家乐官网娱乐城| 百家乐官网打印机分析| 棋牌游戏评测网| 索罗门百家乐的玩法技巧和规则 | 澳门百家乐官网765118118| 游戏厅百家乐官网技巧| 娱乐城彩金| 成都百家乐牌具| 玩百家乐是否有技巧| 南宁百家乐官网的玩法技巧和规则 | 百家乐视频下栽| 百家乐官网二十一点| 乐宝百家乐官网游戏| 大发888 yule| 哪家百家乐优惠最好且信誉不错| 百家乐太阳城娱乐城| 凯斯网百家乐官网的玩法技巧和规则|