zoukankan      html  css  js  c++  java
  • git stash 用法总结和注意点

     

    常用git stash命令:

    (1)git stash save "save message"  : 执行存储时,添加备注,方便查找,只有git stash 也要可以的,但查找时不方便识别。

    (2)git stash list  :查看stash了哪些存储

    (3)git stash show :显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}

    (4)git stash show -p : 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show  stash@{$num}  -p ,比如第二个:git stash show  stash@{1}  -p

    (5)git stash apply :应用某个存储,但不会把存储从存储列表中删除,默认使用第一个存储,即stash@{0},如果要使用其他个,git stash apply stash@{$num} , 比如第二个:git stash apply stash@{1} 

    (6)git stash pop :命令恢复之前缓存的工作目录,将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下,默认为第一个stash,即stash@{0},如果要应用并删除其他stash,命令:git stash pop stash@{$num} ,比如应用并删除第二个:git stash pop stash@{1}

    (7)git stash drop stash@{$num} :丢弃stash@{$num}存储,从列表中删除这个存储

    (8)git stash clear :删除所有缓存的stash

     Git stash

      git stash这个命令可以将当前的工作状态保存到git栈,在需要的时候再恢复

      1.1 git stash 

        保存当前的工作区与暂存区的状态,把当前的工作隐藏起来,等以后需要的时候再恢复,git stash 这个命令可以多次使用,每次使用都会新加一个stash@{num},num是编号

      1.2 git stash pop

        默认恢复git栈中最新的一个stash@{num},建议在git栈中只有一条的时候使用,以免混乱

      1.3 git stash list

        查看所有被隐藏的文件列表

      1.4 git stash apply

        恢复被隐藏的文件,但是git栈中的这个不删除,用法:git stash apply stash@{0},如果我们在git stash apply 的时候工作目录下的文件一部分已经加入了暂存区,部分文件没有,

        当我们执行git stash apply之后发现所有的文件都变成了未暂存的,如果想维持原来的样子,即暂存过的依旧是暂存状态,那么可以使用 git stash apply --index

      1.5 git stash drop

        删除指定的一个进度,默认删除最新的进度,使用方法如git stash drop stash@{0}

      1.6 git stash clear 

        删除所有存储的进度

      1.7 git stash show

        显示stash的内容具体是什么,使用方法如 git stash show stash@{0}

      1.8 查看帮助

        git stash --help

    学习无他法,唯有持之以恒
     

    说明:新增的文件,直接执行stash是不会被存储的,举例如下:

    如上图:在git status 那一步很明显可以看出来,我修改了README,添加了新文件abc.txt,然后执行了git stash save后,在执行git stash list 可以看到刚才的save的信息,然后使用git stash show ,只显示了README的改动被存起来了。

    我们知道,执行了git stash 以后,被存起来的在当前目录再执行git status 就看不到了,但是我们现在再执行git status,如下:

    这个文件还在,说明没有被存起来。说白了就是没有在git 版本控制中的文件,是不能被git stash 存起来的。

    那要怎么办呢,这个文件我也想存起来,很明显,先执行下git add 加到git版本控制中,然后再git stash就可以了,如下:

    最后一步可以看出来,这个新增文件已经被stash了。

    这个时候再执行下git status ,被存起来的在当前目录就看不到了,如下:

    这个时候,想切分支就再也不会报错有改动未提交了。

    如果要应用这些stash,直接使用git stash apply或者git stash pop就可以再次导出来了。

    总结下:git add 只是把文件加到git 版本控制里,并不等于就被stash起来了,git add和git stash 没有必然的关系,但是执行git stash 能正确存储的前提是文件必须在git 版本控制中才行。

    参考的一个链接中说到了以下,我摘录此处备份下(就是只stash一部分文件):

         常规 git stash 的一个限制是它会一下暂存所有的文件。有时,只备份某些文件更为方便,让另外一些与代码库保持一致。一个非常有用的技巧,用来备份部分文件:

    1. add 那些你不想备份的文件(例如: git add file1.js, file2.js)
    2. 调用 git stash –keep-index。只会备份那些没有被add的文件。
    3. 调用 git reset 取消已经add的文件的备份,继续自己的工作。

    参考链接:

    https://blog.csdn.net/jeffasd/article/details/53107182

    http://www.cppblog.com/deercoder/archive/2011/11/13/160007.aspx

    https://blog.csdn.net/baidu_21578557/article/details/52137324

    https://blog.csdn.net/kingboyworld/article/details/76408819

    https://blog.csdn.net/AndyNikolas/article/details/79906132

  • 相关阅读:
    AQS简介
    原子类案例
    保证线程安全的三个方面
    CAS无锁机制
    乐观锁与悲观锁
    读写锁简介
    重入锁简介
    并发队列Queue
    报错Cannot resolve com.mysq.jdbc.Connection.ping method. Will use 'SELECT 1' instead 问题记录
    Springboot中MyBatis 自动转换 map-underscore-to-camel-case
  • 原文地址:https://www.cnblogs.com/sundaysme/p/13427285.html
Copyright © 2011-2022 走看看