【Git必看系列】—— Git巨好用的神器之git stash篇

应用场景

当我们开发一个新功能时会先从master拉出一个分支dev,然后在这个dev分支下吭哧吭哧的开始写代码开发新功能,就如下代码所示,我们在dev分支下开发Person类的新功能getId()

java 复制代码
public class Person {
    private int id;
    private String name;
    private int age;
    public Person(int id) {
        this.id = id;
    }
    // new feature by dev branch
    public int getId() {
        return String;      //  new feature have bug
    }
}

就在此时,线上版本master出现了bug,我们应该放下手头上新功能的开发工作先将master上的bug修复,这个时候dev分支下的改动怎么处理? - 向dev分支提交新功能的代码,然后再切换到master下 - 直接切换到master分支下

首先我们新功能的代码还没开发完成,其次新功能这里还有一些bug没解决,就这样把有问题的代码提交到dev分支中,虽然可以解决目前我们的处境但不是很妥;但是第二种方案,直接切换,明显更不妥。怎么办?我们好像陷入了困境......

![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/9600cc8229e643cb91de43878795e932.jpeg#pic_center)

git stash使用语法

别急,git stash命令恰好可以完美解决该问题!
git stash命令用于暂时保存没有提交的工作。运行该命令后,所有没有commit的代码,都会暂时从工作区移除,回到上次commit时的状态。

它处于git reset --hard(完全放弃还修改了一半的代码)与git commit(提交代码)命令之间,很类似于"暂停"按钮。

js 复制代码
# 暂时保存没有提交的工作
$ git stash
Saved working directory and index state WIP on workbranch: 56cd5d4 Revert "update old files"
HEAD is now at 56cd5d4 Revert "update old files"

# 列出所有暂时保存的工作
$ git stash list
stash@{0}: WIP on workbranch: 56cd5d4 Revert "update old files"
stash@{1}: WIP on project1: 1dd87ea commit "fix typos and grammar"

# 恢复某个暂时保存的工作
$ git stash apply stash@{1}

# 恢复最近一次stash的文件
$ git stash pop

# 丢弃最近一次stash的文件
$ git stash drop

# 删除所有的stash
$ git stash clear

上面命令会将所有已提交到暂存区,以及没有提交的修改,都进行内部保存,没有将工作区恢复到上一次commit的状态。

使用下面的命令,取回内部保存的变化,它会与当前工作区的代码合并。

js 复制代码
$ git stash pop

这时,如果与当前工作区的代码有冲突,需要手动调整。

git stash命令可以运行多次,保存多个未提交的修改。这些修改以"先进后出"的stack结构保存。

git stash list命令查看内部保存的多次修改。

js 复制代码
$ git stash list
stash@{0}: WIP on new-feature: 5cedccc Try something crazy
stash@{1}: WIP on new-feature: 9f44b34 Take a different direction
stash@{2}: WIP on new-feature: 5acd291 Begin new feature

上面命令假设曾经运行过git stash命令三次。

git stash pop命令总是取出最近一次的修改,但是可以用git stash apply指定取出某一次的修改。

js 复制代码
$ git stash apply stash@{1}

git stash子命令一览:

js 复制代码
# 展示目前存在的stash
$ git stash show -p

# 切换回stash
$ git stash pop

# 清除stash
$ git stash clear
相关推荐
Sapphire~5 分钟前
重学JS-012 --- JavaScript算法与数据结构(十二)正则表达式
javascript·数据结构·算法
浪裡遊6 分钟前
HTML面试题
前端·javascript·react.js·前端框架·html·ecmascript
玛卡巴卡0112 分钟前
Maven 从入门到实战:搞定依赖管理与 Spring Boot 项目构建
java·spring boot·maven
Yupureki17 分钟前
从零开始的C++学习生活 20:数据结构与STL复习课(4.4w字全解析)
c语言·数据结构·c++·学习·visual studio·1024程序员节
More more17 分钟前
uniapp实时查看在线监控,JessibucaMobile实现横屏播放
前端·javascript·uni-app·jessibucamobile
vortex525 分钟前
用 Scoop 快速部署 JeecgBoot 开发环境:从依赖安装到服务管理
java·windows·springboot·web·开发·jeecg-boot
FMRbpm1 小时前
顺序表vector--------练习题3题解
数据结构·c++·新手入门
جيون داد ناالام ميづ1 小时前
Spring Boot 核心原理(一):基础认知篇
java·spring boot·后端
i小杨1 小时前
React 状态管理库相关收录
前端·react.js·前端框架
PyAIGCMaster1 小时前
ERR_PNPM_ENOENT ENOENT: no such file or directory, scandir的解决方案
react.js