git stash

git stash 是 Git 的一个实用命令,用于临时保存当前工作目录和暂存区的修改,以便你可以切换到其他分支或任务,稍后再恢复这些更改。以下是关于 git stash 的详细说明和常见用法:


基本用法

  1. 保存当前修改(不包含未跟踪的文件)

    bash 复制代码
    git stash

    等价于:

    bash 复制代码
    git stash push
  2. 保存修改并包含未跟踪的文件(untracked files)

    bash 复制代码
    git stash -u

    或:

    bash 复制代码
    git stash --include-untracked
  3. 保存修改并包含所有文件(包括 ignored 文件)

    bash 复制代码
    git stash -a

    或:

    bash 复制代码
    git stash --all
  4. 添加说明信息(方便识别)

    bash 复制代码
    git stash save "描述信息"

查看存储的 stash 列表

bash 复制代码
git stash list

输出示例:

复制代码
stash@{0}: On main: 描述信息
stash@{1}: On feature-branch: WIP

恢复 stash

  1. 恢复最近一次的 stash 并删除 stash 记录(默认)

    bash 复制代码
    git stash pop
  2. 恢复指定 stash(不删除记录)

    bash 复制代码
    git stash apply stash@{n}

    例如:

    bash 复制代码
    git stash apply stash@{0}
  3. 恢复 stash 并删除记录

    bash 复制代码
    git stash pop stash@{n}

删除 stash

  1. 删除最近一次的 stash

    bash 复制代码
    git stash drop
  2. 删除指定的 stash

    bash 复制代码
    git stash drop stash@{n}
  3. 清空所有 stash

    bash 复制代码
    git stash clear

进阶用法

  1. 将 stash 应用到其他分支

    • 先切换到目标分支,再运行 git stash apply
  2. 从 stash 创建新分支

    bash 复制代码
    git stash branch 新分支名 stash@{n}

    这会基于 stash 的提交创建一个新分支,并自动删除该 stash。

  3. 查看 stash 的差异

    bash 复制代码
    git stash show -p stash@{n}

常见场景示例

场景 1:临时切换分支
bash 复制代码
# 当前有未提交的修改
git stash
git checkout 其他分支
# 完成其他任务后切回原分支
git checkout 原分支
git stash pop
场景 2:保存未完成的实验性代码
bash 复制代码
git stash save "实验性功能A的部分代码"
# 后续恢复
git stash pop
场景 3:误删 stash 后恢复

如果误删了未备份的 stash,可以通过 Git 的引用日志找回:

bash 复制代码
git fsck --unreachable | grep commit | awk '{print $3}' | xargs git show
# 找到对应的提交后,手动恢复

注意事项

  1. 冲突处理

    如果 popapply 时发生冲突,需手动解决冲突后提交。

  2. 未跟踪文件

    默认不保存未跟踪文件(需加 -u-a 参数)。

  3. 长期存储

    Stash 是临时存储,长期未使用的 stash 可能会被垃圾回收(建议提交到分支)。

  4. 安全性

    敏感数据(如密码)不建议存到 stash,可能通过日志泄露。


通过灵活使用 git stash,你可以高效管理临时修改,避免不必要的提交或丢失工作进度!

相关推荐
Dontla10 小时前
脚本:git push直到成功(windows powershell命令)(Github连不上、Github断开)
git·github
CAE虚拟与现实10 小时前
GitHub Desktop 和 Git 命令行工具(CLI)各有优势
git·github·github desktop
RePeaT11 小时前
代码双仓库备份指南:三种简单高效的方法
git·github
coderklaus12 小时前
Git GC
git
xiezhr14 小时前
Git提交错了,别慌!还有后悔药
git·gitlab·github
GGGGGGGGGGGGGG.17 小时前
CI/CD 全链路实践:从 Git 基础到 Jenkins + GitLab 企业级部署
运维·git·ci/cd·云原生·gitlab·jenkins
叫我阿柒啊1 天前
Java全栈开发面试实战:从基础到微服务架构
java·vue.js·spring boot·redis·git·full stack·interview
一只叫煤球的猫1 天前
让版本控制变简单:Jujutsu (jj、git威力加强版) 使用手册
git·程序员·命令行
再难也得平1 天前
如何在IDEA中使用Git
git
再难也得平1 天前
Git分布式版本控制工具
git