git奇技淫巧之临时存储stash

应用场景:

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

由于疏忽,本应该在dev分支开发的内容,却在master上进行了开发,需要重新切回到dev分支上进行开发,可以用git stash将内容保存至堆栈中,切回到dev分支后,再次恢复内容即可。

总的来说,git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容。这也就是说,stash中的内容不仅仅可以恢复到原先开发的分支,也可以恢复到其他任意指定的分支上。git stash作用的范围包括工作区和暂存区中的内容,也就是说没有提交的内容都会保存至堆栈中。

命令详解:

1 git stash

将当前工作目录的临时修改文件存储到暂存区

2 git stash save “test”

git stash save “test"将当前工作目录的临时修改文件存储之暂存区并把添加标签为"test”,与git stash的不同之处就是增加了标签,标签可以自行命名,如:

git stash save "zhang san"
git stash save "li si"

3 git stash list

查看当前所有的暂存stash

4 git stash show

显示做了哪些改动,默认显示第1个存储,如果要显示其他存贮,后面加stash@{$num}
举个栗子:查看第2个暂存

git stash show stash@{
     1}

5 git stash show -p

显示第1个存储的改动,如果想显示其他存存储命令

git stash show stash@{
     $num} -p

举个栗子:查看第3个暂存

git stash show stash@{
     2} -p

6 git stash apply

取出某个存储至暂存区,但不会把存储从存储列表中删除,默认使用第一个存储,即stash@{0},如果要使用其他暂存内容git stash apply stash@{$num}
举个栗子:应用第2个暂存

git stash apply stash@{
     1}

7 git stash pop

命令恢复之前缓存的工作目录,将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下,默认为第一个stash,即stash@{0},如果要应用并删除其他stash,命令:git stash pop stash@{$num}
举个栗子:应用并删除第2个暂存git stash pop stash@{1}

8 git stash drop

丢弃某暂存

git stash drop stash@{
     $num}

丢弃并从列表中删除暂存stash@{$num}

9 git stash clear

清除所有缓存的stash

你可能感兴趣的:(git)