• git stash详解


    stash:保存现场
    1.建议(规范) :在功能未没有开发完毕前,不要commit
    2.规定(必须) : 在没有commit之前,不能chekcout切换分支 (不在同一个commit阶段)
    如果还没有将某一个功能开发完毕 就要切换分支:建议 1.保存现场(临时保存,stash) 2.切换
    保存现场:git stash
    还原现场(默认还原最近一次):
    git stash pop (将原来保存的删除, 用于还原内容)
    git stash apply(还原内容,不删除原保存的内容),可以指定某一次现场git stash apply stash@{1}
    手工删除现场:git stash drop stash@{0}
    查看现场:git stash list
    (了解即可) 如果不同的分支 在同一个commit阶段在,在commit之前,可以chekcout切换分支

    应用场景:

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

    命令详解:

    1 git stash

    能够将所有未提交的修改(工作区和暂存区)保存至堆栈中,用于后续恢复当前工作目录。

    $ git status
    On branch master
    Changes not staged for commit:
      (use "git add ..." to update what will be committed)
      (use "git checkout -- ..." to discard changes in working directory)
    
            modified:   src/main/java/com/wy/CacheTest.java
            modified:   src/main/java/com/wy/StringTest.java
    
    no changes added to commit (use "git add" and/or "git commit -a")
    
    $ git stash
    Saved working directory and index state WIP on master: b2f489c second
    
    $ git status
    On branch master
    nothing to commit, working tree clean
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    2 git stash save

    作用等同于git stash,区别是可以加一些注释,如下:
    git stash的效果:

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

    git stash save “test1”的效果:

    stash@{0}: On master: test1
    
    • 1

    3 git stash list

    查看当前stash中的内容

    4 git stash pop

    将当前stash中的内容弹出,并应用到当前分支对应的工作目录上。
    注:该命令将堆栈中最近保存的内容删除(栈是先进后出)
    顺序执行git stash save “test1”和git stash save “test2”命令,效果如下:

    $ git stash list
    stash@{0}: On master: test2
    stash@{1}: On master: test1
    
    $ git stash pop
    On branch master
    Changes not staged for commit:
      (use "git add ..." to update what will be committed)
      (use "git checkout -- ..." to discard changes in working directory)
    
            modified:   src/main/java/com/wy/StringTest.java
    
    no changes added to commit (use "git add" and/or "git commit -a")
    Dropped refs/stash@{0} (afc530377eacd4e80552d7ab1dad7234edf0145d)
    
    $ git stash list
    stash@{0}: On master: test1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    可见,test2的stash是首先pop出来的。
    如果从stash中恢复的内容和当前目录中的内容发生了冲突,也就是说,恢复的内容和当前目录修改了同一行的数据,那么会提示报错,需要解决冲突,可以通过创建新的分支来解决冲突。

    5 git stash apply

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

    $ git stash apply
    On branch master
    Changes not staged for commit:
      (use "git add ..." to update what will be committed)
      (use "git checkout -- ..." to discard changes in working directory)
    
            modified:   src/main/java/com/wy/StringTest.java
    
    no changes added to commit (use "git add" and/or "git commit -a")
    
    $ git stash list
    stash@{0}: On master: test2
    stash@{1}: On master: test1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    堆栈中的内容并没有删除。
    可以使用git stash apply + stash名字(如stash@{1})指定恢复哪个stash到当前的工作目录。

    6 git stash drop + 名称

    从堆栈中移除某个指定的stash

    7 git stash clear

    清除堆栈中的所有 内容

    8 git stash show

    查看堆栈中最新保存的stash和当前目录的差异。

    $ git stash show
     src/main/java/com/wy/StringTest.java | 2 +-
     1 file changed, 1 insertion(+), 1 deletion(-)
    
    • 1
    • 2
    • 3

    git stash show stash@{1}查看指定的stash和当前目录差异。
    通过 git stash show -p 查看详细的不同:

    $ git stash show -p
    diff --git a/src/main/java/com/wy/CacheTest.java b/src/main/java/com/wy/CacheTest.java
    index 6e90837..de0e47b 100644
    --- a/src/main/java/com/wy/CacheTest.java
    +++ b/src/main/java/com/wy/CacheTest.java
    @@ -7,6 +7,6 @@ package com.wy;
      */
     public class CacheTest {
         public static void main(String[] args) {
    -        System.out.println("git stash test");
    +        System.out.println("git stash test1");
         }
     }
    diff --git a/src/main/java/com/wy/StringTest.java b/src/main/java/com/wy/StringTest.java
    index a7e146c..711d63f 100644
    --- a/src/main/java/com/wy/StringTest.java
    +++ b/src/main/java/com/wy/StringTest.java
    @@ -12,7 +12,7 @@ public class StringTest {
    
         @Test
         public void test1() {
    -        System.out.println("=================");
    +        System.out.println("git stash test1");
             System.out.println(Strings.isNullOrEmpty(""));//true
             System.out.println(Strings.isNullOrEmpty(" "));//false
             System.out.println(Strings.nullToEmpty(null));//""
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

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

    9 git stash branch

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

  • 相关阅读:
    代码规范整理
    编程语言发展史:高级语言的兴起
    【开放问题】代码越少开发效率越高?可能是没被坑过
    JavaScript进阶内容——BOM详解
    神经网络预测应力应变-单轴实验
    好用的Java工具类库—— Hutool
    哲学家和程序员眼中的web3:密码学、分布式与博弈论
    vue将日期数据转换成字符串
    10:00面试,10:06就出来了,问的问题有点变态。。。
    JVM的组成
  • 原文地址:https://blog.csdn.net/qq_41428418/article/details/133648572