git stash 命令详解

发布时间:2022-09-06 20:04:18 作者:yexindonglai@163.com 阅读(3490)

git stash 功能

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

命令详解

1、将代码添加到堆栈区

  1. git stash save "我是注释"
  2. # 如果不想写注释,可以直接这样写,git会自动生成一个注释
  3. git stash

2、查看stash中的内容

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

  1. git stash list

结果如下

  1. D:\java_project\xxx-service>git stash list
  2. 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 弹出
  1. # 将当前stash中的最近添加的内容弹出,因为是栈嘛,所以遵循先进后出的原则
  2. git stash pop
  3. # 如果列表中有多个stash,可以用以下命令弹出指定的行, 其中 stash@{0} 就相当于是索引
  4. git stash pop stash@{0}
3.2、apply 恢复
  1. # 将当前stash中的最近添加的内容恢复,因为是栈嘛,所以遵循先进后出的原则
  2. git stash apply
  3. # 如果列表中有多个stash,可以用以下命令恢复指定的行, 其中 stash@{0} 就相当于是索引
  4. git stash apply stash@{0}

4、清除

  1. # 删除某个暂存,暂存记录保存在list内,需要通过list索引index取出恢复
  2. git stash drop stash@{index}
  3. # 清除堆栈区所有的stash
  4. git stash clear

5、查看改动

  1. # 显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}
  2. git stash show
  3. # 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show stash@{$num} -p ,比如第二个:git stash show stash@{1} -p
  4. git stash show -p

关键字git