这个命令可以将当前的工作区域的代码暂存起来,在需要的时候再恢复使用。
????????在使用git的时候,我们往往会建一个自己的分支去修改和调试代码, 如果别人或者自己发现原有的分支上有个不得不修改的bug,这时,我们不得不暂停手头上的工作,切换到另外的分支去修复错误,我们往往会把完成一半的代码
commit
提交到本地仓库,然后切换分支去修改bug,改好之后再切换回来,这样的话往往log上会有大量不必要的记录。????????如果我们不想提交完成一半或者不完善的代码,但是却不得不去修改一个紧急Bug,那么使用?
git stash?
就可以将你当前未提交到本地(和服务器)的代码推入到Git的栈中,这时候你的工作区间和上一次提交的内容是完全一样的,所以你可以放心的修Bug,等到修完Bug,提交到服务器上后,再使用git stash pop
将以前一半的工作代码恢复回来就可以了。
默认情况下,
git stash
会缓存下列文件:
- 添加到暂存区的修改(staged changes)
- Git跟踪的但并未添加到暂存区的修改(unstaged changes)
但不会缓存以下文件:
- 在工作目录中新的文件(untracked files)
- 被忽略的文件(ignored files)
git stash
命令提供了参数用于缓存上面两种类型的文件。使用
-u
或者--include-untracked
可以stash untracked文件。使用
-a
或者--all
命令可以stash当前目录下的所有修改。
git stash
> 将当前工作区和暂存区的更改保存到一个栈结构
> git stash
> 将当前工作区和暂存区的更改保存到一个栈结构,并附带一个信息> git stash save "message"
> 将当前工作区和暂存区的更改保存到一个栈结构,包括新增的文件?> git stash -u
> git stash --include-untracked
> 将当前工作区和暂存区的更改保存到一个栈结构,包括新增的文件以及忽略的文件> git stash -a
> git stash --all??
git stash list
?> 查看栈中所有保存的更改
> git stash list
git stash show
????????显示做了哪些改动,默认show第一个存储,如果要显示其他存储,后面加stash id,比如第二个 git stash show stash@{1},完整的差异可以使用git stash show -p。
> 查看栈中第一个更改的具体内容
> git stash show
> 查看栈中指定的更改的具体内容
> git stash show <stash id>
git stash apply
????????将stash缓存堆栈中第一个stash应用到当前的工作目录下,但是不会删除缓存堆栈中的缓存,默认使用第一个存储,即stash@{0},应用某个stash后面加stash id。
> 将栈中的第一个更改恢复到当前工作区和暂存区
> git stash apply
> 将栈中的指定的更改恢复到当前工作区和暂存区
> git stash apply <stash id>
git stash drop
????????删除stash@{$num}存储,从列表中删除这个存储,默认删除第一个。
> 删除栈中的第一个更改
> git stash drop
> 删除栈中的指定的更改
> git stash drop <stash id>
git stash pop
> 将栈中的第一个更改恢复到当前工作区和暂存区,同时删除栈中的第一个更改
> git stash pop> 将栈中的指定的更改恢复到当前工作区和暂存区,同时删除栈中的指定的更改
> git stash pop <stash id>
git stash clear
?>?清空栈中保存的更改
> git stash clear
?????????这条命令会根据最近的 stash 创建一个新的分支,然后删除最近的 stash(和 stash pop 一样),如果你需要某个 stash可以指明 stash id。
?