git stash 的用法
1、引言
我们有时会遇到这样的情况,正在dev分支开发新功能,做到一半时有人过来反馈一个bug,让马上解决,但是新功能做到了一半你又不想提交,这时就可以使用git stash命令先把当前进度(工作区和暂存区)保存起来,然后切换到另一个分支去修改bug,修改完提交后,再切回dev分支,使用git stash pop来恢复之前的进度继续开发新功能。下面来看一下git stash命令的常见用法
2、使用方法
2.1 git stash 和 git stash save “”
git stash 存储工作区和缓存区
$ git status
On branch master
Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working directory)modified: src/main/java/com/wy/CacheTest.javamodified: src/main/java/com/wy/StringTest.javano 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
git stash save “test1” :可以为本次存储起名字
2.2 git stash list
查看之前存储的所有版本列表
$ git stash list
stash@{0}: WIP on Practice: 2f70846 Complete practice view and network
stash@{1}: WIP on Practice: 2f70846 Complete practice view and network
stash@{2}: WIP on Practice: 2f70846 Complete practice view and network
stash@{3}: WIP on Practice: 2f70846 Complete practice view and network
stash@{4}: WIP on Practice: 812e77b Add collectionView and AnswerView
stash@{5}: WIP on Practice: 53bb0c1 add tableView of questions and refactor the code of scrollView
2.3 git stash pop [stash_id] 和 git stash apply
1、git stash pop
恢复具体某一次的版本,如果不指定stash_id,则默认恢复最新的存储进度
$ git stash pop stash@{0}
Auto-merging WePeiYang/Shared/Network/SolaSessionManager.swift
CONFLICT (content): Merge conflict in WePeiYang/Shared/Network/SolaSessionManager.swift
Auto-merging WePeiYang/Practice/Practice/QuestionTableView/OptionsCell.swift
CONFLICT (content): Merge conflict in WePeiYang/Practice/Practice/QuestionTableView/OptionsCell.swift
Auto-merging WePeiYang/Practice/Practice/Exercise/Model/ExerciseNetwork.swift
Auto-merging WePeiYang.xcodeproj/project.pbxproj
CONFLICT (content): Merge conflict in WePeiYang.xcodeproj/project.pbxproj
恢复之后,有时打开工程文件,会发现里面所有文件都不翼而飞了?!
莫慌,莫慌
这是因为出现合并冲突的问题而导致工程文件打不开。
这时候右击工程文件,单击“显示包内容”,打开“project.pbxproj”文件,然后command + f 搜索 “stashed”。把冲突部分删掉就可以重新打开啦
2、git stash apply: 将堆栈中的内容应用到当前目录,不同于git stash pop,该命令不会将内容从堆栈中删除,也就说该命令能够将堆栈的内容多次应用到工作目录中,适应于多个分支的情况。
$ git stash apply
On branch master
Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working directory)modified: src/main/java/com/wy/StringTest.javano 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
堆栈中的内容并没有删除。
可以使用 git stash apply + stash名字(如stash@{1})
指定恢复哪个stash到当前的工作目录。
2.4 git stash drop [stash_id]
删除一个存储的进度。如果不指定stash_id,则默认删除最新的存储进度。
$ git stash drop stash@{5}
Dropped stash@{5} (00a18888b0d4c7e9c7d543e9798e7de8df967bc3)
2.5 git stash clear
慎用!!
清除所有的存储进度
2.6 git stash show
查看堆栈中最新保存的stash和当前目录的差异。
$ git stash showsrc/main/java/com/wy/StringTest.java | 2 +-1 file changed, 1 insertion(+), 1 deletion(-)
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 {@Testpublic void test1() {
- System.out.println("=================");
+ System.out.println("git stash test1");System.out.println(Strings.isNullOrEmpty(""));//trueSystem.out.println(Strings.isNullOrEmpty(" "));//falseSystem.out.println(Strings.nullToEmpty(null));//""
同样,通过 git stash show stash@{1} -p
查看指定的stash的差异内容。
2.7 git stash branch
从最新的stash创建分支。
应用场景:当储藏了部分工作,暂时不去理会,继续在当前分支进行开发,后续想将stash中的内容恢复到当前工作目录时,如果是针对同一个文件的修改(即便不是同行数据),那么可能会发生冲突,恢复失败,这里通过创建新的分支来解决。可以用于解决stash中的内容和当前目录的内容发生冲突的情景。
发生冲突时,需手动解决冲突。
参考
https://blog.csdn.net/stone_yw/article/details/80795669
https://www.jianshu.com/p/a634af0eb343
git stash 的用法相关推荐
- git stash的用法
最近在使用Git管理项目工程的时候,遇到了很多问题,也学习到了很多关于Git常见使用的技巧,下面就其中关于Git Stash的用法和大家分享下. 首先,简单介绍下Git Stash命令的用法,详细的用 ...
- Git stash 的用法,将暂存区的内容缓存并移除,解决切换分支前的内容缓存问题
git stash 如果当前分支还有任务没有做完,也不想提交,但此时需要切换或者创建其它分支,就可以使用stash将当前分支的所有修改(包括暂存区)先储藏起来:然后就可以切换到其它分支 在其它分支工作 ...
- git stash用法
原理:git stash 这个命令将当前的工作状态保存到 git 栈,在需要的时候再恢复. 写在前面:从栈中用的时候千万别搞错了!!! 使用场景:多个需求同时开发的时候,需要不同的分支,在一个需求没开 ...
- git stash用法总结
git stash命令的作用就是将目前还不想提交的但是已经修改的内容进行保存,后续可以在任何分支上进行恢复. git stash命令的作用范围包括工作区和暂存区中的内容,也就是说git add但没有g ...
- git stash命令的用法
stash的字面意思:隐藏,储藏 当我们以多人协同工作的方式基于同一个github仓库进行开发时,免不了遇到多人同时在本机对同一文件进行编辑的情况出现. 看一个具体的场景,当我使用git pull时, ...
- git stash用法详解
文章转载自:https://blog.csdn.net/stone_yw/article/details/80795669 应用场景: 当正在dev分支上开发某个项目,这时项目中出现一个bug,需要紧 ...
- Git - stash(暂存区) 用法
使用场景 功能开发一半,改了个BUG需要提交,此时就需要把开发功能的改动代码暂存起来,将BUG修改内容进行提交并推送,推送后再恢复原有改动 执行流程 先git commit要提交的内容 将剩下内容通过 ...
- git stash 个人理解
link git stash (git 储藏)用于以下场景: 1.发现一个类是多余的,想删掉它担心之后会用到它,想保存但又不想增加一个脏的提交,这时候可以考虑使用git stash; 2.使用git的 ...
- git stash参数介绍
git stash 用于暂存工作区未提交的内容,便于在同时开发多个分支需要切换时保存当前分支进度. list 语法 git stash list [<options>] ,与git log ...
最新文章
- Verilog 中输入输出信号的类型?
- 【移动开发】Android中三种超实用的滑屏方式汇总(ViewPager、ViewFlipper、ViewFlow)...
- android 测试网,Android Monkey测试
- 南昌大学c程序计算机作业,南昌大学计算机作业第二章答案
- 云笔记项目-过滤器与拦截器学习
- android Context的使用
- C#中using关键字的使用
- java中非法运算符_Java 中的运算符和流程控制相关内容的理解
- Java——String类的方法
- 国土空间适宜性评价与承载力评价之间的逻辑关系是什么?
- 阿里云CentOS7.3配置Java Web应用和Tomcat步骤
- cent OS 6.3 yum方式安装openldap,phppldapadmin,lam
- 工程线性代数 matlab版,工程线性代数(MATLAB版)
- 华罗庚数学竞赛如何报名?
- linux怎么用水星无线,用手机设置水星路由器步骤_手机设置mercury无线路由器-192路由网...
- 安徽理工大学计算机设计大赛,安徽理工大学学子在2020年中国大学生计算机设计大赛中喜获佳绩...
- DAY9 :划词翻译字典 goldendict 使用教程
- python的快捷键是什么意思_Python基础知识—快捷键
- 为什么别人进步你退步,你应该如何提升自己
- 嵌入式linux+程序构架,从头开始构建一个嵌入式 Linux 发行版
热门文章
- 【C++】逆向与反汇编实战--PEiD分析复现
- 【机器学习技巧】回归模型的几个常用评估指标(R2、Adjusted-R2、MSE、RMSE、MAE、MAPE)及其在sklearn中的调用方式
- 网络协议 一 网络层( 版本、首部长度、区分服务、总长度、 标识、标志、片偏移生存时间、协议、首部校验和)
- PySide6中QlineEdit设置自动所有字母大写以及首字母大写的案例
- python3 value counts函数_Pandas Series.value_counts()实例介绍
- 应对突发事件PPStream断点续播
- [转]尼采:快乐的知识(下)
- SQuAD 数据预处理(1)
- Robocup 仿真2D 学习笔记(四)阵型编辑
- 2020-10-22在线识图搜索引擎