假设你正在为你的产品增加一项新需求。正在编写新需求代码时,突然出现了一起客户投诉的Bug。这时,你不得不暂时放下手头上的新需求一段时间。你还不能commit未完成的代码,当然你也肯定不想把已经写好的代码给丢弃掉。所以你需要一些临时的存储空间,这些空间你可以用来存储未完成的改变并在稍后commit它。
在Git中,stash操作可以将你的一系列修改保存起来,并保证在你需要的任何时候能重新运用它。
[Jeremy@MagicWorld project]$ git status
-s
M string.c
?? string
现在你要转换branch到客户投诉的问题上来,但是你不想commit已经写过但未完成的代码。所以你需要stash这些改变,并push这个新的stash到你的stack上。以上这些操作只需要运行git stash的命令:
[Jeremy@MagicWorld project]$ git stash
Saved working directory and index state WIP on master: e86f062 Added my_strcpy function
HEAD is now at e86f062 Added my_strcpy function
上面操作结束后, 你的working directory并不会发生改变,因为所有的改变都已经保存在了stack上。可以通过git status命令去验证是不是这样。
[Jeremy@MagicWorld project]$ git status -s
?? string
到目前为止,你可以安全地切换你的branch并在其他分支上编写代码。而我们只需要通过git stash list命令就可以查看已经被stash过的一系列改变。
[Jeremy@MagicWorld project]$ git stash list
stash@{0}: WIP on master: e86f062 Added my_strcpy function
假设现在你已经解决了客户投诉的问题,你要回到新需求的编写上来继续未完成的代码,你只需直接执行git stash pop命令就可以。这个命令可以把stack上存放的改变给清空,同时把这些改变放置到你当前的working directory中。
[Jeremy@MagicWorld project]$ git status -s
?? string
[Jeremy@MagicWorld project]$ git stash pop
现在你就可以继续你未完成的工作了。
上面所说的命令会出现以下这些结果:
# On branch master
# Changed but not updated:
# (use "git add ..." to update what will be committed)
# (use "git checkout -- ..." to discard changes in working directory)
#
#
modified: string.c
#
# Untracked files:
# (use "git add ..." to include in what will be committed)
#
#
string
no changes added to commit (use "git add" and/or "git commit -a")
Dropped refs/stash@{0} (36f79dfedae4ac20e2e8558830154bd6315e72d4)
[Jeremy@MagicWorld project]$ git status -s
M string.c
?? string
本文翻译自Git - Stash Operation如有转载请注明出处,谢谢!
Tips:
stash : vt. 存放;贮藏