Git stash命令详解和使用

stash的原理:
将本地没提交的内容(git commit的内容不会被缓存 但git add的内容会被缓存)进行缓存并从当前分支移除,缓存的数据结构为堆栈,先进后出

stash的参数详解:
#1. git stash/git stash save
git stashgit stash save是一样的,将没有提交的内容缓存并移除,而这条缓存名称为最新一次提交的commit -m的内容,如果没有本地提交则是拉远程仓库是的commit内容

git stash save "xxx"
加上自己的注解进行缓存

有个问题需要注意些:
stash 只会操作被git追踪的文件
在这里插入图片描述

stash后新增的文件并没有进入缓存,这是因为git还没有追踪这个新增的文件,所以需要进行git add [文件名]让git追踪这文件,再进行stash就可以对新文件进行操作
在这里插入图片描述

#2. git stash list
返回缓存的列表

#3. git stash pop
将堆栈中最新的内容pop出来应用到当前分支上,且会删除堆中的记录
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9GBiyc88-1596533858866)(:storage/06dd817c-9aab-4550-968c-2187d70a221c/0a85c279.png)]

看pop后面有一行是Dropped,在堆栈中删除了这个缓存
如果pop出来的内容有冲突,git会中断此次pop并告知你需要进行冲突解决
也可以指定堆栈中的记录通过在git stash pop后面加上git stash list中的名称(举例:git stash pop stash@{0})

#4. git stash apply
与pop相似,但他不会在堆栈中删除这条缓存,适合在多个分支中进行缓存应用
也可以进行指定git stash apply stash@{0}

#5. git stash drop/git stash clear
git stash drop [名]删除单个缓存 举例git stash drop stash@{0}
git stash clear全清

#6. git stash show
git stash show [名]显示与当前分支差异 举例git stash show stash@{0} 加上-p可以看详细差异

#7. git stash branch
指定或最新缓存创建分支

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐