命令:stash
把工作空间的修改存放起来,从而保持工作空间的clean,完成操作后再恢复。
场景:
- 写了一些东西了,突然需要切换到其他分支(比如打个包?)
- 本地有一些文件不能提交,也不方便写在.gitignore中,这个时候想用rebase的方式来pull代码(避免merge时产生的commit)
你当然可以写一个commit,然后再reset;但使用stash(存放)是更合适的。
用法:
- 存放本地修改
git stash
- 还原之前存放的修改
git stash pop
场景Detail:
切换分支的场景就不说了,很常规。
下面说一下在本地修改未提交的情况下,如何使用rebase方式pull更新
有些人不喜欢merge产生的commit,会给git时间线增加很多分叉,于是人们使用rebase来合并commit.
如果你的操作严格地符合git规范,那么这个场景很正常,就没啥可说的了。可在实际开发中,我们常常会有这些的问题:
一些本地文件不能提交,也不方便加入.gitignore中
一些修改也不能提交,于是在本次修改commit后,工作空间会留下一些的东西。
data:image/s3,"s3://crabby-images/93d7d/93d7d5edc23cf81f823882884e58b2840eb4af55" alt=""
这个时候你要提交了,先更新代码,于是你使用
git pull --rebase
(为啥用rebase前面已经说了),看到下面的错误:
data:image/s3,"s3://crabby-images/eb44d/eb44d2ed4898127c8e2c15ace26addb1e11a6a59" alt=""
这个时候只需要存放一下,
data:image/s3,"s3://crabby-images/fa442/fa4423ed637b33117368ca08188ccf5c25aaf8a6" alt=""
发现工作空间已经clean了:
data:image/s3,"s3://crabby-images/02f34/02f3499cb8abc617cc9cc4dfeb873f479b3526ba" alt=""
这个时候,就可以愉快地rebase了
data:image/s3,"s3://crabby-images/1549c/1549c23794180d1716993ee890298f914ed41559" alt=""
最后,恢复存放的数据:
data:image/s3,"s3://crabby-images/fa9bc/fa9bc9958154648249d91ecf6f4fd733e60ec4fd" alt=""
更多内容,参考doc
网友评论