为什么我们需要它
不得不说,在知道这个命令的时,以及之后的使用中,我都超级热爱这个命令,因为它真的太好用了。
给大家说一下我使用这个命令的场景:
此时我在 feature_666 分支,非常聚精会神加持高专注地实现一个功能 666 模块,简直键盘如飞的编写代码~~~
然后这时,客户反馈出一个 bug , 非常严重,必须立马解决,优先级为 0 !!!
于是,我需要去到 release 分支去 checkout 新的分支去工作了,但是 666 功能还没完成怎么办?
此时我面临着一个选择题:
A:提交后切换,代码保存到分支 feature_666,却产生一个无意义的提交
B:不提交直接切换,然而这个选项根本没人会选。
是不是很难选,此时,别忘记还有 C 选项!
C:使用 git stash , 将当前修改(未提交的代码)存入缓存区,切换分支修改 bug ,回来再通过 git stash pop 取出来。
1. 暂存操作
#查看当前状态 git status #如果有修改,添加修改文件 git add . #暂存操作 git stash save '本次暂存的标识名字'
2. 查看当前暂存的记录
#查看记录 git stash list
修改存储到什么位置了?
当我们使用 git init给项目添加版本控制的时候,会在项目路径下生成一个 .git 隐藏文件夹。.git 中存储着版本管理的所有信息。
.git/refs/stash 中,存储的是最后一个 stash 对应的节点指针
同样,在 .git/log/refs/stash 中可以看到我们全部的 stash 记录信息
存储多个 stash 的情况
ok ,我们来尝试一下修改文件,然后再次使用 git stash ,此时我们有个两个 暂存修改,那么怎么查看呢?
git stash list //查看暂存区的所有暂存修改记录
如果在未提交的情况下,执行 git stash 两次,无法准确分辨两个stash 具体修改的是哪些内容,这样用,显的伟大的 Git 一点都不智能,怎么可以!。
所以,在这种情况下,给 stash 存储的修改起个名字,显然非常重要,方式如下:
git stash save <message>
3. 恢复暂存的工作
‘pop命令恢复,恢复后,暂存区域会删除当前的记录'
#恢复指定的暂存工作, 暂存记录保存在list内,需要通过list索引index取出恢复 git stash pop stash@{index}
‘apply命令恢复,恢复后,暂存区域会保留当前的记录'
#恢复指定的暂存工作, 暂存记录保存在list内,需要通过list索引index取出恢复 git stash apply stash@{index}
4. 删除暂存
#删除某个暂存, 暂存记录保存在list内,需要通过list索引index取出恢复 git stash drop stash@{index} #删除全部暂存 git stash clear
到此这篇关于git stash暂存的操作方法的文章就介绍到这了,更多相关git stash暂存内容请搜索尊托云数以前的文章或继续浏览下面的相关文章希望大家以后多多支持尊托云数!
一、概述 在园子里面有很多关于各种技术细节的研究文章,都是比较牛逼的框架研究...
本章目录 1.面向过程和面向对象的初步认识 2.类的引入 3.类的定义 4.类的访问限...
JSP页面上通过JS实现消息弹出框,样式可根据要求修改,这边只是一个简单的示范例...
IT之家3月23日消息微软、谷歌昨日联合宣布,将与 Igalia 等公司以及开放社区合作...
关于Java数组的那些事 数组是 相同数据类型 的元素的 有序 集合。 为什么说是有...
本文实例讲述了AJAX+JSP实现读取XML内容并按排列显示输出的方法。分享给大家供大...
首先废话不多说,先把激活补丁分享给大家,拿走不谢! WebStorm真永久激活补丁下载 ...
实例如下所示: mui.init(); mui.plusReady(function() { document.getElementBy...
博主最近在做一个个人的博客网站,准备用 thymeleaf 实现一个动态加载一二级文章...
语法:grep 选项 ‘word' filename -c:打印符合要求的行数 -i:不区分大小写 -n...