git stash 命令详解

git stash 功能

当正在dev分支上开发某个项目,这时项目中出现一个bug,需要紧急修复,但是正在开发的内容只是完成一半,还不想提交,这时可以用git stash命令将修改的内容保存至堆栈区,然后顺利切换到hotfix分支进行bug修复,修复完成后,再次切回到dev分支,从堆栈中恢复刚刚保存的内容。

命令详解

1、将代码添加到堆栈区
shell 复制代码
git stash save "我是注释"

# 如果不想写注释,可以直接这样写,git会自动生成一个注释
git stash
2、查看stash中的内容

此命令可以查看已保存到堆栈区的stash列表

复制代码
git stash list

结果如下

复制代码
D:\java_project\xxx-service>git stash list
stash@{0}: WIP on develop: 1380db3 Merge remote-tracking branch 'origin/develop' into develop
3、恢复

恢复暂存时的状态有两种命令:

  • git stash pop :恢复后,会将stash列表中的信息进行删除。
  • git stash apply :恢复后,stash列表中的信息是会继续保留的.
3.1 pop 弹出
复制代码
# 将当前stash中的最近添加的内容弹出,因为是栈嘛,所以遵循先进后出的原则
git stash pop

# 如果列表中有多个stash,可以用以下命令弹出指定的行, 其中 stash@{0} 就相当于是索引
git stash pop stash@{0}
3.2、apply 恢复
复制代码
# 将当前stash中的最近添加的内容恢复,因为是栈嘛,所以遵循先进后出的原则
git stash apply

# 如果列表中有多个stash,可以用以下命令恢复指定的行, 其中 stash@{0} 就相当于是索引
git stash apply stash@{0}
4、清除
复制代码
# 删除某个暂存,暂存记录保存在list内,需要通过list索引index取出恢复
git stash drop stash@{index}

# 清除堆栈区所有的stash
git stash clear
5、查看改动
复制代码
# 显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}
git stash show 

# 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show  stash@{$num}  -p ,比如第二个:git stash show  stash@{1}  -p
git stash show -p
相关推荐
SelectDB13 小时前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
AlfredZhao14 小时前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode2 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220703 天前
如何搭建本地yum源(上)
运维
A小辣椒4 天前
TShark:Wireshark CLI 功能
linux
A小辣椒4 天前
TShark:基础知识
linux
AlfredZhao4 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
AlfredZhao5 天前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
用户9718356334665 天前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux