news 2026/4/15 20:27:49

Git - git stash的使用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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. 恢复存储的修改

# 恢复最新的 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

# 删除最新的 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恢复,但比较复杂
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/8 23:21:36

20、深入了解Samba:打印服务、用户与组管理

深入了解Samba:打印服务、用户与组管理 1. 配置Samba打印服务的点和打印策略 在使用Samba提供打印服务时,配置点和打印策略是关键步骤。以下是具体的操作步骤: 1. 启用策略并选中“Users can only point and print to these servers:”复选框,然后输入Samba服务器的完全限…

作者头像 李华
网站建设 2026/4/11 18:22:16

7、探索去中心化网络:Mixmaster与Gnutella的技术魅力

探索去中心化网络:Mixmaster与Gnutella的技术魅力 在当今数字化的时代,网络技术的发展日新月异,其中去中心化的网络技术正逐渐崭露头角。Mixmaster和Gnutella作为其中的代表,为我们展示了去中心化网络的独特魅力和巨大潜力。本文将深入探讨这两种技术,揭示它们的工作原理…

作者头像 李华
网站建设 2026/4/13 20:23:34

四足机器人控制系统整体分析(1212)

文章目录初步的技术路线图:1. 舵机安装时的初始化2. 组装完机器人后的舵机微调3. 网页端控制机器人前进并返回技术实现要点:系统架构图:初始代码讲解一、整体结构是干啥的?二、舵机驱动层1. 角度 → 脉宽2. ServoDriver3. 舵机引脚…

作者头像 李华
网站建设 2026/4/15 9:52:50

24、Samba 4 作为 AD 兼容域控制器的配置与管理指南

Samba 4 作为 AD 兼容域控制器的配置与管理指南 1. 配置 NTP 要使 Active Directory 正常工作,时间同步是必不可少的。可以通过以下步骤安装和启动 NTP 服务: [root@mike ~]# yum -y install ntp [root@mike ~]# systemctl start ntpd [root@mike ~]# systemctl enable n…

作者头像 李华
网站建设 2026/4/15 3:51:09

43、深入解析 Groove 共享空间及其安全机制

深入解析 Groove 共享空间及其安全机制 1. Groove 共享空间简介 在数据交换领域,传统方式难以满足用户构建高效、连贯且可复制的多应用工作空间的需求。而 Groove 的共享空间为我们提供了一个更优的解决方案。 共享空间本质上是一个 XML 对象存储的副本。对象的增量更改会以…

作者头像 李华
网站建设 2026/4/14 3:19:08

Minecraft存档修复工具终极使用指南:从损坏区块到完美恢复

Minecraft存档修复工具终极使用指南:从损坏区块到完美恢复 【免费下载链接】Minecraft-Region-Fixer Python script to fix some of the problems of the Minecraft save files (region files, *.mca). 项目地址: https://gitcode.com/gh_mirrors/mi/Minecraft-Re…

作者头像 李华