当前位置:   article > 正文

git stash 用法小结_git 查看stash

git 查看stash

场景

有一天你正兴高采烈地coding…,突然现网出现一个bug让你紧急修复,但是你本地已经有了修改,你又不想提交,也总不能全部回退吧,所以你正发愁怎么办的时候恰好看到了这篇文章,它将帮你完美解决此场景的困扰,那么今天的主角就是 git stash,它会本地保存当前工作目录所有未提交的修改(每个工作目录有自己的缓存堆栈),不会上传到git服务器,在你需要的时候应用到你当前的分支(一定要注意要应用的分支是否是当时保存该stash的分支)

命令

1. 保存修改

下列两个命令都会保存当前工作目录所有未提交的修改,工作区的代码会回退到未修改之前,但有区别。

git stash
  • 1

保存成功如图:
在这里插入图片描述
使用该命令保存的stash没有注释,难以分辨

git stash save 'xxx' // 'xxx'表示注释,便于区分每个stash
  • 1

保存成功如图:
在这里插入图片描述
使用该命令保存的stash有注释,容易分辨

注意:未被git跟踪的代码(新增)不会被stash存储,会报 No local changes to save

2. 查看stash列表

git stash list
  • 1

当我们使用 git stash 命令保存多个stash时,stash列表如下:
在这里插入图片描述
我们可以看到,两个stash除了前面的序号不同,其他信息都一模一样,很难分辨哪个是我们现在需要应用的stash。
而当我们使用 git stash save ‘xxx’ 命令保存多个stash时,stash列表如下:
在这里插入图片描述
是不是容易分辨多了?还没完,接着看↓

3. 查看差异及详细信息

查看堆栈中最新保存的stash和当前目录的差异:

git stash show
  • 1

用法:
在这里插入图片描述
我们可以看到修改的文件。
我们如果想查看指定的stash和当前目录差异,可以使用:

git stash show stash@{index}
  • 1

用法:
在这里插入图片描述
有的同学说这只能看到文件,看不到详细的内容啊,别急,用这个:

git stash show -p
  • 1

用法:
在这里插入图片描述
我们可以很直观地看到修改了哪些地方。
当然,我们要是想看到指定的stash的详细修改,可以使用:

git stash show stash@{index} -p
  • 1

用法:
在这里插入图片描述
nice!!!还没完,接着看↓

4. 应用stash

git stash pop
  • 1

当只有一个stash的时候,我们大可使用 git stash pop 命令将该stash应用到当前分支:
在这里插入图片描述
值得注意的是,git stash pop 命令默认将缓存中第一个stash应用到当前分支,并且应用完后会删除该stash,我们查看一下stash列表:
在这里插入图片描述

那么有的同学就会问:那我应用完不想删除stash怎么办?
此时主角闪亮登场⭐:

git stash apply
  • 1

我们先复原刚刚删除掉的stash,再使用该命令应用stash:
在这里插入图片描述
使用该命令不会删除缓存的stash,并且与 git stash pop 同样默认将缓存中第一个stash应用到当前分支,同样我们看一下stash列表:
在这里插入图片描述
很显然,二老健在

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/756769
推荐阅读
相关标签