git学习(5)---git stash

https://segmentfault.com/q/1010000006706178
https://wenku.baidu.com/view/6a25f40653d380eb6294dd88d0d233d4b14e3f35.html
https://blog.csdn.net/stone_yw/article/details/80795669git stash 和git commit区别

 

 

git stash应用场景:

1、如果当前修改的代码不是提交的最终版本不想commit,但想将远程代码pull下来,则会报错:error: 您对下列文件的本地修改将被合并操作覆盖。

2、为了fix一个紧急的bug,先stash,使返回到自己上一个commit,改完bug之后再stash pop,继续原来的工作。

可以在git commit之前可以先git stash。git stash可用来暂存当前正在进行的工作。

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


2 由于疏忽,本应该在dev分支开发的内容,却在master上进行了开发,需要重新切回到dev分支上进行开发,可以用git stash将内容保存至堆栈中,切回到dev分支后,再次恢复内容即可。
总的来说,git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存至堆栈中,后续可以在某个分支上恢复出堆栈中的内容。这也就是说,stash中的内容不仅仅可以恢复到原先开发的分支,也可以恢复到其他任意指定的分支上。git stash作用的范围包括工作区和暂存区中的内容,也就是说没有提交的内容都会保存至堆栈中。

步骤:

1、git stash 

# 先将本地修改存储起来
git stash

结果: 

其中stash@{0} 就是刚才保存的标记。

 

 

2、git pull

---- do some work

3、git stash pop stash@{0}

将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。该命令将堆栈中最近保存的内容删除(栈是先进后出)

如果其中有冲突,需要解决其中的冲突。

 

 

 

stash相关命令:

1、git stash 

2、git stash save : 作用同git stash, 区别是可以加一些注释。

git stash的效果:

stash@{0}: WIP on master: b2f489c second

git stash save “test1”的效果:

stash@{0}: On master: test1

3、git stash list:查看当前stash的内容

4、git stash pop :将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。该命令将堆栈中最近保存的内容删除(栈是先进后出)

5、 git stash apply:将堆栈中的内容应用到当前目录,不同于git stash pop,该命令不会将内容从堆栈中删除,也就说该命令能够将堆栈的内容多次应用到工作目录中,适应于多个分支的情况。

6 git stash drop + 名称:从堆栈中移除某个指定的stash

7 git stash clear:清除堆栈中的所有 内容

8 git stash show:查看堆栈中最新保存的stash和当前目录的差异。通过 git stash show -p 查看详细的不同

同样,通过git stash show stash@{1} -p查看指定的stash的差异内容。

9 git stash branch

从最新的stash创建分支。
应用场景:当储藏了部分工作,暂时不去理会,继续在当前分支进行开发,后续想将stash中的内容恢复到当前工作目录时,如果是针对同一个文件的修改(即便不是同行数据),那么可能会发生冲突,恢复失败,这里通过创建新的分支来解决。可以用于解决stash中的内容和当前目录的内容发生冲突的情景。
发生冲突时,需手动解决冲突。

 


posted on 2019-09-05 11:12  吱吱了了  阅读(216)  评论(1编辑  收藏  举报

导航