日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

git常用命令之stash

發布時間:2025/4/16 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 git常用命令之stash 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

git stash(git儲藏)可用于以下情形:

  • 發現有一個類是多余的,想刪掉它又擔心以后需要查看它的代碼,想保存它但又不想增加一個臟的提交。這時就可以考慮git stash。
  • 使用git的時候,我們往往使用分支(branch)解決任務切換問題,例如,我們往往會建一個自己的分支去修改和調試代碼, 如果別人或者自己發現原有的分支上有個不得不修改的bug,我們往往會把完成一半的代碼commit提交到本地倉庫,然后切換分支去修改bug,改好之后再切換回來。這樣的話往往log上會有大量不必要的記錄。其實如果我們不想提交完成一半或者不完善的代碼,但是卻不得不去修改一個緊急Bug,那么使用git stash就可以將你當前未提交到本地(和服務器)的代碼推入到Git的棧中,這時候你的工作區間和上一次提交的內容是完全一樣的,所以你可以放心的修Bug,等到修完Bug,提交到服務器上后,再使用git stash apply將以前一半的工作應用回來。
  • 經常有這樣的事情發生,當你正在進行項目中某一部分的工作,里面的東西處于一個比較雜亂的狀態,而你想轉到其他分支上進行一些工作。問題是,你不想提交進行了一半的工作,否則以后你無法回到這個工作點。解決這個問題的辦法就是git stash命令。儲藏(stash)可以獲取你工作目錄的中間狀態——也就是你修改過的被追蹤的文件和暫存的變更——并將它保存到一個未完結變更的堆棧中,隨時可以重新應用。

git stash用法

1. stash當前修改

git stash會把所有未提交的修改(包括暫存的和非暫存的)都保存起來,用于后續恢復當前工作目錄。
比如下面的中間狀態,通過git stash命令推送一個新的儲藏,當前的工作目錄就干凈了。

$ git status On branch master Changes to be committed:new file: style.cssChanges not staged for commit:modified: index.html$ git stash Saved working directory and index state WIP on master: 5002d47 our new homepage HEAD is now at 5002d47 our new homepage $ git status On branch master nothing to commit, working tree clean

需要說明一點,stash是本地的,不會通過git push命令上傳到git server上。
實際應用中推薦給每個stash加一個message,用于記錄版本,使用git stash save取代git stash命令。示例如下:

$ git stash save "test-cmd-stash" Saved working directory and index state On autoswitch: test-cmd-stash HEAD 現在位于 296e8d4 remove unnecessary postion reset in onResume function $ git stash list stash@{0}: On autoswitch: test-cmd-stash

2. 重新應用緩存的stash

可以通過git stash pop命令恢復之前緩存的工作目錄,輸出如下:

$ git status On branch master nothing to commit, working tree clean $ git stash pop On branch master Changes to be committed:new file: style.css Changes not staged for commit: modified: index.html Dropped refs/stash@{0} (32b3aa1d185dfe6d57b3c3cc3b32cbf3e380cc6a)

這個指令將緩存堆棧中的第一個stash刪除,并將對應修改應用到當前的工作目錄下。
你也可以使用git stash apply命令,將緩存堆棧中的stash多次應用到工作目錄中,但并不刪除stash拷貝。命令輸出如下:

$ git stash apply On branch master Changes to be committed:new file: style.cssChanges not staged for commit: modified: index.html

3. 查看現有stash

可以使用git stash list命令,一個典型的輸出如下:

$ git stash list stash@{0}: WIP on master: 049d078 added the index file stash@{1}: WIP on master: c264051 Revert "added file_size" stash@{2}: WIP on master: 21d80a5 added number to log

在使用git stash apply命令時可以通過名字指定使用哪個stash,默認使用最近的stash(即stash@{0})。

4. 移除stash

可以使用git stash drop命令,后面可以跟著stash名字。下面是一個示例:

$ git stash list stash@{0}: WIP on master: 049d078 added the index file stash@{1}: WIP on master: c264051 Revert "added file_size" stash@{2}: WIP on master: 21d80a5 added number to log $ git stash drop stash@{0} Dropped stash@{0} (364e91f3f268f0900bc3ee613f9f733e82aaed43)

或者使用git stash clear命令,刪除所有緩存的stash。

5. 查看指定stash的diff

可以使用git stash show命令,后面可以跟著stash名字。示例如下:

$ git stash showindex.html | 1 +style.css | 3 +++2 files changed, 4 insertions(+)

在該命令后面添加-p或--patch可以查看特定stash的全部diff,如下:

$ git stash show -p diff --git a/style.css b/style.css new file mode 100644 index 0000000..d92368b --- /dev/null +++ b/style.css @@ -0,0 +1,3 @@ +* { + text-decoration: blink; +} diff --git a/index.html b/index.html index 9daeafb..ebdcbd2 100644 --- a/index.html +++ b/index.html @@ -1 +1,2 @@ +<link rel="stylesheet" href="style.css"/>

6. 從stash創建分支

如果你儲藏了一些工作,暫時不去理會,然后繼續在你儲藏工作的分支上工作,你在重新應用工作時可能會碰到一些問題。如果嘗試應用的變更是針對一個你那之后修改過的文件,你會碰到一個歸并沖突并且必須去化解它。如果你想用更方便的方法來重新檢驗你儲藏的變更,你可以運行 git stash branch,這會創建一個新的分支,檢出你儲藏工作時的所處的提交,重新應用你的工作,如果成功,將會丟棄儲藏。

$ git stash branch testchanges Switched to a new branch "testchanges" # On branch testchanges # Changes to be committed: # (use "git reset HEAD <file>..." to unstage) # # modified: index.html # # Changes not staged for commit: # (use "git add <file>..." to update what will be committed) # # modified: lib/simplegit.rb # Dropped refs/stash@{0} (f0dfc4d5dc332d1cee34a634182e168c4efc3359)

這是一個很棒的捷徑來恢復儲藏的工作然后在新的分支上繼續當時的工作。

7. 暫存未跟蹤或忽略的文件

默認情況下,git stash會緩存下列文件:

  • 添加到暫存區的修改(staged changes)
  • Git跟蹤的但并未添加到暫存區的修改(unstaged changes)

但不會緩存一下文件:

  • 在工作目錄中新的文件(untracked files)
  • 被忽略的文件(ignored files)

git stash命令提供了參數用于緩存上面兩種類型的文件。使用-u或者--include-untracked可以stash untracked文件。使用-a或者--all命令可以stash當前目錄下的所有修改。

至于git stash的其他命令建議參考Git manual。

轉載于:https://www.cnblogs.com/xingxia/p/git_stash.html

總結

以上是生活随笔為你收集整理的git常用命令之stash的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 成人性视频网站 | 欧美在线aa | www.五月天婷婷 | 伊人操| 亚洲精品欧洲 | 国产91在线免费观看 | 欧美国产不卡 | 成人欧美一区二区三区在线观看 | 国产综合区 | 樱花草av | 日韩欧美综合视频 | 精品无码国产污污污在线观看 | 黄色理论视频 | 成人羞羞在线观看网站 | 在线国产精品视频 | 91狠狠爱| 亚洲欧美网址 | www.香蕉视频 | 免费成人深夜夜 | 国产成人av免费观看 | 色宗合| 毛茸茸亚洲孕妇孕交片 | 四虎影视免费永久观看在线 | 国产女人18毛片水真多18精品 | 操三八男人的天堂 | 国产精品第9页 | 欧美国产成人精品一区二区三区 | 亚洲第一色 | 欧美激情免费观看 | 黄视频网站在线 | 无遮挡裸光屁屁打屁股男男 | 能在线观看的av网站 | 国产白浆视频 | 亚洲av无码一区二区三区在线 | 日本成人免费在线视频 | 草久久免费视频 | 欧美精品自拍视频 | 国产熟女一区二区三区四区 | 在线亚洲不卡 | 久久久久一区二区 | 手机看片一区二区 | 超碰v | 日本a级黄色 | 91亚洲精选| 天天色成人网 | 涩涩国产 | 夜夜高潮夜夜爽国产伦精品 | 久久久久久久国产精品毛片 | 尤物videos另类xxxx | 丰满少妇xbxb毛片日本 | 色妇av| 国产女女做受ⅹxx高潮 | 奇米狠狠操 | 99re在线视频免费观看 | 日韩乱论 | 99久久精品国产一区二区三区 | 玖玖综合网 | 调教在线观看 | 男同av在线观看一区二区三区 | 黄色资源在线观看 | 国产精品一区二区三区在线播放 | 亚洲熟女综合色一区二区三区 | 97欧美视频 | 精品美女 | 国产欧美精品aaaaaa片 | 国产污视频在线播放 | 无码国产精品一区二区免费式直播 | 女同性做爰全过程 | 久操伊人网 | 91麻豆精品国产理伦片在线观看 | 欧美干干 | 成人午夜小视频 | 波多野吉衣视频在线观看 | 欧美中文字幕一区二区三区 | 欧美寡妇性猛交ⅹxxx | 日韩高清精品免费观看 | 国产成人无码精品久久久久久 | 男人激烈吮乳吃奶爽文 | 农村老熟妇乱子伦视频 | 久艹在线 | 在线观看一区视频 | 肉丝美脚视频一区二区 | 99re免费视频精品全部 | 日韩免费福利 | 超碰97人人射妻 | 国产一级精品视频 | 一级黄色片片 | 精品动漫一区二区三区在线观看 | 九九国产 | 久色99| 九九免费 | 日本黄色a级片 | 欧美在线视频免费 | 97精品一区二区三区 | 亚洲熟妇一区 | 久久五十路| 在线欧美一区 | 日本精品二区 | 吖v在线 |