Git stash命令的详细使用说明及案例分析。

Git stash命令在版本控制系统操作中作为一个非常有用的功能,允许用户临时保存当前工作目录中的更改并清理工作目录,使其回到最近的提交状态,便于切换分支或暂时撤回更改,而不丢失工作进度。

基本使用

创建Stash

复制代码
git stash
​

这个命令将会保存工作目录和暂存区的当前更改。执行这个命令后,你的工作目录将是干净的,与最后一次提交的状态相同。

查看Stash列表

复制代码
git stash list
​

此命令显示了所有的stash项。默认情况下,stash项被命名为 stash@{0}, stash@{1}, stash@{2}, 依此类推,其中 stash@{0}是最新的stash。

应用Stash

复制代码
git stash apply
​

该命令恢复最新的stash内容。如果需要恢复指定的stash项,可以使用:

kotlin 复制代码
git stash apply stash@{n}
​

其中 n是要恢复的stash的编号。

删除Stash项

kotlin 复制代码
git stash drop stash@{n}
​

通过此命令可以删除指定的stash项。

恢复Stash并删除Stash项

perl 复制代码
git stash pop
​

这个命令将应用最上面的stash并将其从stash列表中删除。

清空所有Stash项

arduino 复制代码
git stash clear
​

执行后,所有缓存的stash项都会被删除。

高级使用

保存未暂存的更改

默认情况,git stash不会保存未暂存的更改。如果也想保存这些更改,可以使用:

css 复制代码
git stash -k
git stash --keep-index
​

包含未跟踪的文件

如果工作目录有未跟踪的文件,可以使用以下命令将它们也加入到stash中:

css 复制代码
git stash -u
git stash --include-untracked
​

创建带有描述的stash

arduino 复制代码
git stash save "Your custom message"
​

这样可以为stash项添加一个描述,方便以后识别。

案例分析:

假定你正在开发一个功能,在开发的中途,你需要切换到其他分支处理一个紧急的bug。

  1. 保存当前进度
    首先存储当前的工作进度,使工作目录干净:

    git stash

  2. 切换分支修复bug

bash 复制代码
git checkout fix-bug-branch
# ... 解决bug ...
git commit -am "Fix bug"
​
  1. 返回之前的工作

    git checkout feature-branch

  2. 恢复进度

接着,你可以使用以下命令恢复你的工作进度:

perl 复制代码
git stash pop
​

此时,之前保存的更改将会重新应用到工作目录,并且该更改会从stash列表中删除。

通过上述案例,我们看到stash命令能够在不丢失进度的情况下,帮助开发者临时切换开发上下文,这在处理多个任务或紧急bug时特别有用。正确使用Git stash可以大大提高开发的灵活性和效率。

相关推荐
kfaino4 小时前
码农的AI翻身(三)你好,我叫 Embedding
后端·ai编程
葫芦和十三5 小时前
图解 MongoDB 18|复制集拓扑:Primary、Secondary 和 Arbiter 的分工
后端·mongodb·面试
爱勇宝5 小时前
大多数人不是在使用 AI 赚钱,而是在帮 AI 公司赚钱
前端·后端·程序员
冬奇Lab6 小时前
每日一个开源项目(第143篇):page-agent - 纯 JS 的网页 GUI Agent,无需截图、无需插件、无需后端
前端·人工智能·agent
程序员cxuan8 小时前
虽迟但到!GPT-5.6 终于来了!
人工智能·后端·程序员
IT_陈寒10 小时前
React的这个渲染问题连官方文档都没说清楚
前端·人工智能·后端
葫芦和十三11 小时前
图解 MongoDB 15|journal 与持久化:写入怎么不丢,崩溃怎么恢复
后端·mongodb·面试
葫芦和十三11 小时前
图解 MongoDB 16|压缩:snappy、zstd 和 zlib 的取舍
后端·mongodb·面试
苍何11 小时前
终于找到免费开源TTS模型,克隆声音不要钱,本地电脑也能跑
后端
用户5936087414012 小时前
Spring AI 集成 DeepSeek 原生供应商并实现think模式
后端