Git的stash操作

假设你正在为你的产品增加一项新需求。正在编写新需求代码时,突然出现了一起客户投诉的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. 存放;贮藏

转载于:https://juejin.im/post/5a31f0226fb9a04528468070

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值