一、前言
在使用Git过程中,有时当你在项目的其它分支正在进行开发,并且该分支还尚未开发完成进行提交,这个时候需要你切换分支进行工作,这个时候做到一半的工作既不想全部丢掉又不想到处都是问题的就commit,十分冲突。解决问题的方法就是 git stash 命令 贮藏(stash)会处理工作目录的脏的状态——即跟踪文件的修改与暂存的改动——然后将未完成的修改保存到一 个栈上, 而你可以在任何时候重新应用这些改动(甚至在不同的分支上)。 如果你的文件是新建文件且没有被跟踪,这个时候stash 命令是不会生效的。
二、git stash命令演示
1、现有分支如下,stashtest分支为目前正在开发的分支,test分支为我们需要切换的分支。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/545e6a9ac7b54304b024f06fcc5b9105.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_17,color_FFFFFF,t_70,g_se,x_16) 2、修改test.txt 文件内容,在文件中添加内容作为我们正在开发的功能,此功能未开发完成,这个时候需要切换到test分支进行修改可以使用如下命令进行贮藏(stash)
git stash save “贮藏的信息”
![在这里插入图片描述](https://img-blog.csdnimg.cn/c29c89c53e8e48cbb8680d489d0cccd9.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_17,color_FFFFFF,t_70,g_se,x_16) ![在这里插入图片描述](https://img-blog.csdnimg.cn/d186811c80dd463d89f0e1a6fdc80529.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_20,color_FFFFFF,t_70,g_se,x_16) 3、当我们的工作区没有改动以后就可以放心的切换到其它分支进行开发,当开发完成后在切换回stashtest分支,将贮藏的内容从栈中弹出,继续未完成的工作内容。命令:
git stash pop stash@{序号}
![在这里插入图片描述](https://img-blog.csdnimg.cn/fff73158ec6c4884ad9d72783d32ef45.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_19,color_FFFFFF,t_70,g_se,x_16) 4、查看贮藏列表,贮藏与分支无关,可以将在僧ashtest分支上的贮藏在test分支弹出,命令:
git stash list
![在这里插入图片描述](https://img-blog.csdnimg.cn/34553cb7ad4f4292b1b157467882b46e.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_18,color_FFFFFF,t_70,g_se,x_16) 5、在stashtest分支添加一个新文件stash.txt,如果不执行git add . 将新增文件添加追踪的话,git stash 是无法对其生效的 ![在这里插入图片描述](https://img-blog.csdnimg.cn/ecb9455832d245739573cf5e5e1bd484.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_20,color_FFFFFF,t_70,g_se,x_16) 6、追踪将新增加的文件,并将其贮藏 ![在这里插入图片描述](https://img-blog.csdnimg.cn/e6a30010f7254b35bb444d06b39672a4.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_20,color_FFFFFF,t_70,g_se,x_16) 7、查看stash 中的改动,如果不指定序号,默认为第一次贮藏的改动内容。命令:
git stash show stash@{序号} -p
![在这里插入图片描述](https://img-blog.csdnimg.cn/3345054ebb344209a1ca09d582b7d88b.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_17,color_FFFFFF,t_70,g_se,x_16) 8、当我们不想弹出贮藏List中最近一次的改动时,可以按序号弹出贮藏,命令:
git stash pop stash@{序号}
![在这里插入图片描述](https://img-blog.csdnimg.cn/0c06e6307d9346b9a6f3a4effbdfd64b.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_16,color_FFFFFF,t_70,g_se,x_16) 9、通过 git stash pop 命令我们可以看到当弹出序号为1的贮藏以后,贮藏列表中同时已经删除了对应的贮藏,如果有需要的话,可以使用 git stash apply 命令当弹出变更,但是贮藏列表中不删除弹出的该贮藏变更,命令:
git stash apply stash@{序号}
![在这里插入图片描述](https://img-blog.csdnimg.cn/9c94f2a8e1264c59b2af83a5df7cacea.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_18,color_FFFFFF,t_70,g_se,x_16) 10、当我们不想要某个贮藏,可以使用删除命令,命令:
git stash drop stash@{需要}
![在这里插入图片描述](https://img-blog.csdnimg.cn/8dd37821d7a94fcfb0341d7e238dcb57.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_19,color_FFFFFF,t_70,g_se,x_16) 11、清空贮藏列表,命令:
git stash clear
![在这里插入图片描述](https://img-blog.csdnimg.cn/1b06dbeecb554318b520c82907d1e40f.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA6L-95Yiw5LmM5LqR55qE5bC95aS05om-5aSq6Ziz,size_17,color_FFFFFF,t_70,g_se,x_16)
三、git stash命令总结
(1)git stash save “贮藏的信息” 存贮被追踪的改动
(2)git stash list 显示贮藏列表
(3)git stash show stash@{序号} -p 显示某个贮藏的变动
(4)git stash pop stash@{序号} 弹出某个贮藏,并在贮藏列表中删除该贮藏
(5)git stash apply stash@{序号} 弹出某个贮藏,但不在贮藏列表中删除
(6)git stash drop stash@{需要} 删除贮藏
(7)git stash clear 清空所有贮藏
|