git stash臨時保存工作區

????????通過git stash?可以靈活管理臨時修改,保持工作區整潔,是多人協作或多任務切換時的常用工具,主要用于臨時保存工作區和暫存區修改的命令,常用于以下場景:

(1)需要切換分支,但不想立即提交當前修改;

(2)臨時拉取或合并遠程代碼,避免沖突;

(3)調試時保存中間狀態,方便后續恢復。

注意事項:

(1)git stash?不保存已提交的內容(已在版本歷史中);

(2)恢復儲藏后,若有沖突需手動解決(類似合并沖突);

(3)儲藏記錄保存在本地倉庫,不會推送到遠程,需謹慎依賴長期儲藏。

1、使用示例

????????比方說線上有緊急BUG需要修復,但當前我的一個新功能開發只進行到一半,都不一定能跑通,代碼不能提交。這個時候,可以使用git stash將當前工作區暫存(隱藏起來),拉取最新代碼,修改后提交修復bug。之后再回復自己的暫存區,繼續開發。

# 1.當前工程開發一半,有文件hangar_box/stop_task_save.sh不能提交
git status
On branch master
Your branch is up to date with 'origin/master'.Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified:   hangar_box/stop_task_save.shno changes added to commit (use "git add" and/or "git commit -a")# 2.git stash暫存工作區
$ git stash save "暫存區測試" -u   # 注意:-u 加在最后
warning: LF will be replaced by CRLF in hangar_box/stop_task_save.sh.
The file will have its original line endings in your working directory
Saved working directory and index state On master: 暫存區測試
再次實行git status,顯示工作區間干凈# 3.拉取最新代碼更新提交# 4.恢復工作區,如果跟步驟3文件沖突,相當于做了一次合并
git stash apply

2、基本用法

2.1、保存當前修改

????????保存當前修改。會將工作區和暫存區的所有修改(未跟蹤文件默認不保存)存入一個臨時 "儲藏區",并將工作區恢復到上一次提交的干凈狀態。

git stash # 保存當前修改
git stash save "修復登錄bug的臨時修改" # 保存時添加說明

2.2、查看儲藏列表

git stash list # 查看儲藏列表

輸出類似:

stash@{0}: On feature/login: 修復登錄bug的臨時修改
stash@{1}: WIP on main: 8a3b2c1 初始提交

????????stash@{n}?是儲藏的索引,n?越小表示越新的儲藏。

2.3、恢復儲藏的修改

git stash apply 恢復最新的儲藏(并保留儲藏記錄)
git stash apply stash@{1}  # 恢復指定儲藏,如:恢復第2條儲藏
git stash pop  # 相當于 apply + drop,恢復最新的儲藏(并刪除儲藏記錄)

2.4、刪除儲藏記錄

git stash drop # 刪除最新的儲藏,不要輕易刪儲存,除非確定不用它了
git stash drop stash@{1} # 刪除指定儲藏
git stash clear # 刪除所有儲藏

3、進階用法

3.1、保存未跟蹤文件

????????默認不保存未跟蹤文件(如新建的文件),需加?-u?或?--include-untracked:

git stash -u  # 保存時支持對新建文件的添加
git stash save "修復登錄bug的臨時修改" -u # 保存時添加說明

3.2、保存所有文件(包括忽略的文件)

????????用?-a?或?--all?保存未跟蹤文件和?.gitignore?中忽略的文件:

git stash -a

3.3、從儲藏創建分支

????????若儲藏的修改與當前分支沖突,可直接從儲藏創建新分支:

git stash branch new-branch stash@{1}

4、恢復刪除的存儲

????????如果通過?git stash drop?或?git stash clear?誤刪了 stash 存儲,只要沒有執行過?git gc(Git 垃圾回收)清理未引用的對象,通常可以通過以下方法找回:

步驟 1:找到被刪除的 stash 對應的 commit ID

????????Git 的所有 stash 本質上都是以 commit 對象的形式存儲的,即使被刪除,也能通過 reflog 找到記錄。執行以下命令查看所有 stash 相關的操作記錄:

git reflog show stash@{0} # 查看所有 stash 相關的操作記錄
git reflog # 或查看所有引用的變更記錄(包含 stash 的創建和刪除)

????????輸出結果中會包含類似這樣的記錄(重點關注?WIP on ?相關的條目):

a1b2c3d (HEAD -> main) HEAD@{0}: stash: WIP on main: 8a3b2c1 初始提交
e4f5g6h HEAD@{1}: stash: WIP on feature/login: 修復登錄bug的臨時修改

????????其中?a1b2c3d、e4f5g6h?就是 stash 對應的 commit ID(完整 ID 可通過?git log -g?查看)。

步驟 2:恢復指定的 stash 記錄

????????找到目標 stash 的 commit ID 后,有兩種恢復方式:

方式 1:重新創建 stash 條目(推薦)

????????用?git stash apply 直接應用該 commit 的修改,同時會自動重新創建一個 stash 記錄:

git stash apply e4f5g6h

方式 2:從 commit 創建新分支(適合有沖突的情況)

????????如果直接應用有沖突,可基于該 stash 創建新分支:

git branch recover-stash e4f5g6h

????????然后切換到新分支查看修改:

git checkout recover-stash

注意事項:

????????時效性:被刪除的 stash 會作為 “未引用對象” 存在,默認情況下 Git 會在 30 天后通過?git gc?自動清理。如果刪除時間過長且執行過垃圾回收,可能無法找回。

????????快速操作:發現誤刪后,應立即執行?git reflog?查找記錄,避免執行?git gc?或等待自動清理。

????????驗證內容:恢復后建議用?git diff?或?git status?確認找回的修改是否正確。

????????如果以上方法仍無法找回,可能是 stash 對應的 commit 已被徹底清理,這種情況下恢復難度極大,建議平時重要的臨時修改盡量通過分支管理(而非長期依賴 stash)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/93630.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/93630.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/93630.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Vue 3.5+ Teleport defer 屬性詳解:解決組件渲染順序問題的終極方案

&#x1f4cb; 概述 Vue 3.5 引入了 Teleport 的 defer 屬性&#xff0c;這是一個重要的延遲解析特性。傳統的 Teleport 在組件掛載時會立即解析目標容器&#xff0c;而 defer 屬性允許推遲 Teleport 的目標解析&#xff0c;直到應用的其他部分掛載完成。 ?? 傳統 Teleport …

【102頁PPT】某著名企業智能制造解決方案及智能工廠產品介紹(附下載方式)

篇幅所限&#xff0c;本文只提供部分資料內容&#xff0c;完整資料請看下面鏈接 https://download.csdn.net/download/2501_92808811/91662620 資料解讀&#xff1a;某著名企業智能制造解決方案及智能工廠產品介紹 詳細資料請看本解讀文章的最后內容 智能制造背景與整體規劃…

Revisiting Character-level Adversarial Attacks for Language Models

文章目錄**核心設計目標****關鍵步驟與實現細節**1. **候選位置選擇&#xff08;Algorithm 1: get_top_locations&#xff09;**2. **擾動生成與篩選&#xff08;Algorithm 2: Charmer&#xff09;**3. **適配大語言模型&#xff08;LLM&#xff09;的攻擊****實驗中的性能表現…

(一)Python + 地球信息科學與技術 (GeoICT)=?

目錄 引子 一、核心定位&#xff1a;Python 為何能重塑 GeoICT&#xff1f; 二、Python 在 GeoICT 中的關鍵應用領域 1. 空間數據處理&#xff08;GIS 基礎&#xff09; 2. 遙感圖像處理與解譯 3. 空間分析與建模 4. 地學數據可視化 5. 時空大數據分析 三、Python GeoI…

OpenAI 發布了 GPT-5,有哪些新特性值得關注?國內怎么使用GPT5?

GPT-5很強&#xff0c;在LMAreana上獲得了1481分&#xff0c;超過Gemini 2.5 Pro&#xff0c;奪回第一。 國內怎么使用GPT5&#xff1f;-> zhangfeidezhu.com/?p1033 這次發布的GPT-5系列包含三個模型&#xff1a; GPT-5&#xff1a;適合復雜推理、廣泛的世界知識&#x…

PowerPoint和WPS演示放映PPT時如何禁止鼠標翻頁

在演示播放PPT的時候&#xff0c;我們有時候會用鼠標在幻燈片上劃重點&#xff0c;一不小心就點擊了鼠標左鍵&#xff0c;而默認的鼠標左鍵是向下翻頁&#xff08;下一步&#xff09;。可以簡單設置一下&#xff0c;禁用鼠標翻頁的功能&#xff0c;改為其他方式翻頁。一、禁用/…

基于springboot養老院管理系統 畢業論文+項目源碼及數據庫文件

&#xff01;&#xff01;&#xff01; 有需要的小伙伴可以通過文章末尾名片咨詢我哦&#xff01;&#xff01;&#xff01; &#x1f495;&#x1f495;作者&#xff1a;優創學社 &#x1f495;&#x1f495;個人簡介&#xff1a;本人在讀博士研究生&#xff0c;擁有多年程序開…

Meteodyn WT 6.7(Meteodyn)風力資源評估及微觀選址軟件工具

Meteodyn WT 6.7&#xff08;Meteodyn&#xff09;風力資源評估及微觀選址軟件工具&#xff0c;基于計算流體力學&#xff08;CFD&#xff09;技術&#xff0c;主要用于復雜地形下的風能評估和風電場選址。該軟件由法國政府環境與能源署&#xff08;ADEME&#xff09;支持開發&…

計算機網絡 TCP time_wait 狀態 詳解

TCP 的 TIME_WAIT 狀態是 TCP 連接終止過程中 主動關閉連接的一方&#xff08;通常是先調用 close() 或主動發送 FIN 的一端&#xff09;進入的一個重要狀態。理解其原理、副作用和優化策略對高性能網絡編程和服務器調優至關重要。&#x1f50d; 一、TIME_WAIT 是什么&#xff…

《GuardHFL: Privacy Guardian for Heterogeneous Federated Learning》——論文閱讀

研究背景&#xff1a;異構聯邦中各客戶端模型結構&#xff0c;精度&#xff0c;算力都不同&#xff0c;無法像傳統聯邦那樣共享梯度&#xff0c;只能通過“查詢-響應”使用輔助數據來訓練模型。這種方法存在嚴重隱私問題&#xff1a;直接共享查詢樣本會泄露敏感信息&#xff0c…

Spring AI 進階之路01:三步將 AI 整合進 Spring Boot

引子 當 LLM 的浪潮以不可阻擋之勢席卷全球&#xff0c;從改變用戶交互到重塑商業模式&#xff0c;我們每一位開發者都身處這場技術變革的中心。作為龐大的 Java 生態中的一員&#xff0c;你是否也曾思考&#xff1a;當 Python 似乎成為 AI 的“官方語言”時&#xff0c;我們這…

pycharm2025導入anaconda創建的各個AI環境

目錄1.pycharm下載及安裝2.導入anaconda的環境到pycharm項目中1.pycharm下載及安裝 建議從官網下載&#xff0c;不要亂下載。 https://www.jetbrains.com.cn/en-us/pycharm/ 右上角可以切換中英文&#xff0c;在此切換為中文。 點擊下載&#xff0c;如下頁面: 點擊中間下載w…

獲取IPv6地址的三種方式

DHCPv6無狀態自動分配IP地址Server 配置&#xff1a;<Huawei>system-view[Huawei]ipv6[Huawei]dhcp enable[Huawei]dhcpv6 pool pool1[Huawei-dhcpv6-pool-pool1]dns-server 2002::2[Huawei-dhcpv6-pool-pool1]dns-domain-name example.com[Huawei-dhcpv6-pool-pool1]qui…

[Oracle數據庫] Oracle 復雜查詢

對于剛接觸 Oracle 數據庫的初學者來說&#xff0c;簡單查詢&#xff08;如SELECT * FROM 表名&#xff09;可能不難掌握&#xff0c;但面對復雜業務場景時&#xff0c;就需要更強大的查詢能力。本文將圍繞 Oracle 復雜查詢的核心知識點展開&#xff0c;包括條件邏輯、分組函數…

Redis-plus-plus API使用指南:通用操作與數據類型接口介紹

&#x1f351;個人主頁&#xff1a;Jupiter.&#x1f680; 所屬專欄&#xff1a;Redis 歡迎大家點贊收藏評論&#x1f60a;目錄通用 API連接 Redis1. get/set2. exists 方法3. del 方法4. keys 方法5. expire 方法6. ttl 方法7. type 方法8. flushall 方法String 類型 API1. ge…

基于遺傳編程的自動程序生成

這里寫目錄標題核心概念與工作原理1. 個體表示&#xff1a;樹結構2. 初始化種群3. 適應度評估4. 選擇5. 遺傳操作&#xff08;繁殖&#xff09;6. 新一代種群形成7. 終止條件基于遺傳編程的符號回歸示例問題示例GP實現符號回歸&#xff08;Deap&#xff09;GP實現符號回歸&…

flowable匯總查詢方式

背景&#xff1a;小程序開發申請流程。使用flowable流程框架。用戶需要在后臺統攬用戶申請的匯總表。 設計思路&#xff1a;通過查詢流程實例分頁查詢獲取數據&#xff0c; 其中可以通過查詢條件進行查詢&#xff0c;查詢條件是流程申請時添加到流程變量當中的&#xff0c;方便…

力扣438:找到字符串中所有的字母異位詞

力扣438:找到字符串中所有的字母異位詞題目思路代碼題目 給定兩個字符串 s 和 p&#xff0c;找到 s 中所有 p 的 異位詞 的子串&#xff0c;返回這些子串的起始索引。不考慮答案輸出的順序。 思路 我們先不看異位詞這個條件&#xff0c;如何在字符串s中找到字符串p。我們可以…

ruoyi-vue(十一)——代碼生成

大部分項目里其實有很多代碼都是重復的&#xff0c;幾乎每個基礎模塊的代碼都有增刪改查的功能&#xff0c;而這些功能都是大同小異&#xff0c; 如果這些功能都要自己去寫&#xff0c;將會大大浪費我們的精力降低效率。所以這種重復性的代碼可以使用代碼生成。一 代碼生成使用…

neo4j導入導出方法

在 Neo4j 中&#xff0c;如果需要將數據從 一個環境導出&#xff0c;再 導入到另一個環境&#xff08;如從開發環境遷移到生產環境&#xff09;&#xff0c;可以通過以下方法實現&#xff1a;方法 1&#xff1a;使用 neo4j-admin 導出和導入&#xff08;完整數據庫遷移&#xf…