Git - git stash的使用

git stash的作用:

  • git stash作为临时保存工作目录中的修改,而不需要提交这些更改。
  • 将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容。
  • stash中的内容不仅仅可以恢复到原先开发的分支,也可以恢复到其他任意指定的分支上。

git stash作用范围:

  • 工作区
  • 暂存区

git stash的使用情况:

  • 切换分支但不想提交当前的工作
  • 紧急修复 其它分支的bug
  • 清理工作区以进行其他操作
  • 测试不同的代码版本

git stash的特点:

  • 先进后出,后进先出

git stash的使用

前期准备:在dev分支中创建test1.txt,test2.txt文件,跟踪test1.txt文件(将test1.txt添加到暂存区)

1. 保存当前修改

只保存工作区的修改

  • 作用范围:

    • 工作区中已跟踪文件的修改

    • 暂存区中的修改

    • 不包括:未跟踪的新文件

    • 不包括:被 .gitignore 忽略的文件

      保存未提交的修改(包括暂存区)

      newfile.txt不会被保存

      git stash

      添加描述信息

      git stash save "描述信息"

包含未跟踪的文件

  • 作用范围:

    • 所有已跟踪文件的修改

    • 暂存区中的修改

    • 未跟踪的新文件

    • 不包括:被 .gitignore 忽略的文件

      包含未跟踪的文件(新增的文件)

      git stash -u

      或 git stash --include-untracked

包含所有文件

  • 作用范围:

    • 所有已跟踪文件的修改

    • 暂存区中的修改

    • 未跟踪的新文件

    • 被 .gitignore 忽略的文件

      包含所有文件(包括被忽略的文件)

      git stash -a

      或 git stash --all

不同作用范围的对比表格

命令 工作区修改 暂存区修改 未跟踪文件 被忽略文件
git stash
git stash -u
git stash -a

2. 查看存储的stash

on dev:后的版本值为上一次提交的版本值

复制代码
# 查看 stash 列表
git stash list

# 输出示例:
# stash@{0}: On main: 描述信息
# stash@{1}: On feature: 另一个修改

3. 恢复存储的修改

bash 复制代码
# 恢复最新的 stash(不删除 stash)
git stash apply

# 恢复指定的 stash
git stash apply stash@{n}

# 恢复并删除 stash(推荐)
git stash pop

# 恢复指定的 stash 并删除
git stash pop stash@{n}

情况一:在当前分支dev下取栈

情况二:切换到另一个分支dev2上取栈


4. 删除stash

bash 复制代码
# 删除最新的 stash
git stash drop

# 删除指定的 stash
git stash drop stash@{n}

# 删除所有 stash
git stash clear

常见的面试问题

⭐stash 和 commit 有什么区别?

  • stash:临时保存,没有提交信息,适合临时切换
  • commit:正式提交,有提交历史,适合版本记录

⭐stash 保存到哪里?

  • stash 内容存储在 .git/refs/stash 和 .git/logs/refs/stash 中

⭐stash 会过期吗?

  • 不会,stash 会一直存在直到你删除它

⭐如何恢复已删除的 stash?

  • 可以通过 git fsck --unreachable 查找,然后使用 git show 恢复,但比较复杂
相关推荐
天若有情6735 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
海盗12346 小时前
在群晖NAS上使用Git Server
git
y小花6 小时前
git常用指令
git
华科大胡子6 小时前
开源项目 Git 贡献全流程拆解
git
极地星光7 小时前
工程中:Git 子模块(submodule) vs 直接依赖(源码/库/包管理器)
git
无限进步_8 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
无限进步_9 小时前
【C++】验证回文字符串:高效算法详解与优化
java·开发语言·c++·git·算法·github·visual studio
无限进步_12 小时前
【C++】重载、重写和重定义的区别详解
c语言·开发语言·c++·ide·windows·git·github
历程里程碑12 小时前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github
华科大胡子13 小时前
Git + 云原生
git