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,你可以高效管理临时修改,避免不必要的提交或丢失工作进度!

相关推荐
T - mars3 小时前
Pycharm中使用git
ide·git·pycharm
jason_yang5 小时前
Workspace搭建Vue3+组件分离的Monorepo项目
git·npm·前端工程化
鸽鸽程序猿9 小时前
【Git】Git 简介及基本操作
git
ziyue757519 小时前
idea终端添加git-bash,支持linux的shell语法
linux·git·bash·idea·软件
风也温柔☆1 天前
idea 拉取分支git pull报错 The branch to pull from should be selected
git·intellij-idea·debug·git pull
博闻善行1 天前
git基础操作
运维·git
黑面前端小书生1 天前
Git 下载 、安装、规范
git
Rhys..1 天前
Git & GitHub 个人账户创建教程
git·github
wuyunhang1234561 天前
Git----常用指令入门
git
越千年1 天前
Git的“后悔药”全指南:reset、revert、restore 如何优雅地拯救手残
git