[Git] 020 stash —— Git 中的”皮姆粒子“
0. 我准备模拟两种情况
第一种

第二种

情况简析
- 仓库中的最新版本发现 Bug,需要立即修复
- 当前在 "dev" 分支中工作到一定程度,尚不能提交,但删之可惜
ps: 在分支中没有提交就切其他分支,改动部分会被覆盖
- 下面是 "Git" 的温馨提示
error: Your local changes to the following files would be overwritten by checkout:
...
Please commit your changes or stash them before you switch branches.
Aborting `
1. 解决方案
1.1 题外话
- 单片机中有个“中断函数”,意为停止事件 A,优先处理事件 B,处理完后再回来继续 A 的工作
- 电影《蚁人 2》中,皮姆博士暴露了行踪,而他身处的大楼里有他的心血。最后,他的“皮姆粒子”没有让他失望!他将整座大楼缩小成一个行李箱,实力证明”跑得了和尚,也跑得了庙“!
- 金刚琢、乾坤一气袋之类的说下去就没底了
1.2 "stash" —— "Git" 中的”皮姆粒子“
- 当前的工作就好像皮姆博士的那栋大楼
- "stash" 就好像“皮姆粒子”
- "stash" 可以把“大楼”化作“行李箱”,放到一边;等找到“合适的地皮”后,再把“行李箱”恢复成“大楼”
2. 第一种情况的制造与解决
2.1 目前的情况

2.2 没有条件,创造条件
2.1.1 开一条分支
- 切到该分支
- 新建一个文档 "note_02.txt"
- 往 "note_02.txt" 中写入文本,并保存



2.2.2 查看当前状态

2.3 有了条件,解决问题
2.3.1 使用“皮姆粒子”
- 命令:
git stash

- 因为 "note_02.txt" 并没有添加至暂存区,所以有个反馈
2.3.2 切换分支
- 切到 "master" 分支
- 另开一条分支 "stash_1",并切入

- 此时的情况

2.3.3 修复 Bug
- 打开 "note_01.txt",将 "5. master round 3.1" 中的 "round" 改为 "version",并保存

2.3.4 添加 & 提交

2.3.5 切换 & 合并
- 切到 "master" 分支
- 合并 "stash_01" 分支

- 这里没有用 "--no-ff",情形二再用
2.3.6 删除分支

2.3.7 再次使用“皮姆粒子”
- "statsh" 有个参数 "list",用来查看“行李箱”

- 上图的 "list" 像极了 "reflog"
- 上图的 "stash@{0}" 像极了 "HEAD@{n}"
- 可以多次使用
git stash - 恢复时,可以选择指定的“行李箱”,语法:
git stash apply stash@{n}
- 可以多次使用
- 恢复

- 恢复有两种方法
- 方法一:
git stash apply+git stash drop - 方法二:
git stash pop
- 方法一:
2.4 解决问题后,观察一下“日志”

- 没有增加提交次数
- 哈希值也没有变
3. 第二种情况的制造与解决
3.1 准备活动
3.1.1 在 "dev" 分支将文件添加至暂存区

- 因为 "2.2.1" 的第 3 步,"note_02.txt" 是在 "Git Bash" 用 "vim" 写入数据的,所以有个格式提醒
- 我给 "note_02.txt" 转了格式后,用
git status查看了一下
3.1.2 在 "dev" 分支将文件提交给本地仓库

3.1.3 切到 "master" 分支并合并

3.1.4 查看“日志”

- "2.4" 中没有看到的那次 "commit" 与其哈希值在这里显现了
3.2 开始创造条件
3.2.1 目前的情况

3.2.2 切换分支
- 切到 "dev" 分支
- 修改 "note_01.txt"
- 将 "note_01.txt" 添加至暂存区

- 注意,这里的 "note_01.txt" 的状态是在暂存区
3.2.3 “无中生有”
- 假设 "3.2.1" 的图中,"master" 分支的 "commit (n+2)" 被 YorkFish 找出一个 Bug,需要立即修复
3.3 开始修复 Bug
3.3.1 使用“皮姆粒子”
- 与情形一相似,我就不多费口舌了

- 这次使用 "--no-ff" 与 "pop"

3.3.2 一个注意点
- 我在 "3.2.2" 将 "note_01.txt" 加入暂存区了,但现在的显示表明暂存区没有收入

- 挖坑:探索暂存区“消失”的文档
- 坑号编码:Git20-1
[Git] 020 stash —— Git 中的”皮姆粒子“的更多相关文章
- git stash pop 冲突,git stash list 中的记录不会自动删除的解决方法
在使用git stash代码时,经常会碰到有冲突的情况,一旦出现冲突的话,系统会认为你的stash没有结束. 导致的结果是git stash list 中的列表依然存在,实际上代码已经pop出来了. ...
- 关于Git的stash命令
add 添加新文件到 Git 代码仓库的索引中 $ git add filename mv 移动或重命名文件 $ git mv old-filename new-filename rm 从工作目录和 ...
- git submodule 使用过程中遇到的问题
git submodule 使用过程中遇到的问题 资源文件 原.gitmodules文件的内容如下: [submodule "Submodules/FFmpegWrapper"] ...
- git在实际开发中的应用
PS: git操作实例(https://learngitbranching.js.org/?demo) 一, 创建分支,合并分支到master 1. 在远程仓库中创建master和test分支 2.本 ...
- 第23月第24天 git命令 .git-credentials git rm --cached git stash clear
在git push的时候,有时候我们会想办法撤销git commit的内容 1.找到之前提交的git commit的id git log 找到想要撤销的id 2.git reset –hard id ...
- git 彻底删除历史记录中的大文件
Reference 大家一定遇到过在使用Git时,不小心将一个很大的文件添加到库中,即使删除,记录中还是保存了这个文件.以后不管是拷贝,还是push/pull都比较麻烦. === 删除大文件方法 方法 ...
- git pull和git merge区别&&Git冲突:commit your changes or stash them before you can merge. 解决办法
http://blog.csdn.net/sidely/article/details/40143441 原文: http://www.tech126.com/git-fetch-pull/ Git中 ...
- git从远程仓库中更新代码到本地仓库
git从远程仓库中更新代码到本地仓库 有时候在使用git pull的时候,会莫名才报错.查了很多资料,尝试过git的很多命令.包括git fetch命令,都会报同样的错.最后终于发现了一条捷径,由网友 ...
- git branch stash
一.branch(分支) 1.创建分支 git branch dev 2.切换分支 git branch dev 3.合并分支 git merge bug 4.查看分支 git branch 5.删除 ...
随机推荐
- HDU-3416-MarriageMatch4(最大流,最短路)
链接: https://vjudge.net/problem/HDU-3416 题意: Do not sincere non-interference. Like that show, now sta ...
- pyqt5-QTDesigner--UI文件的使用方式
方式一:直接加载UI文件 from PyQt5.QtWidgets import QApplication, QWidget import sys class win(QWidget): def __ ...
- ESP8266 SPI通信
设备与设备之间的通信往往都伴随着总线的使用,而用得比较多的就当属于SPI总线和I2C总线,而恰巧NodeMcu也支持这两种总线通信 1. SPI总线——SPI类库的使用 SPI是串行外设接口(Seri ...
- rsync快速部署记录
rsync快速部署记录 安装rsync和使用环境:客户端:10.192.30.59 fudao_db_cluster_002 (将本地文件备份到服务端)服务端:10.192.30.60 fudao_d ...
- 015:URLs分层模块化
URLs分层模块化: 经过上面的14节课程,大伙有没有发现一个问题:那就是随着的项目功能模块越来越多,所有url匹配都写在一个urls.py文件中,其结果是:文件长,看着心累——需要分门别类:因此能不 ...
- JavaScript求取水仙花数
一.什么是水仙花数 水仙花数也称为超完全数字不变数.自幂数.阿姆斯壮数.阿姆是特朗数. 水仙花数是指一个三位数,每个位数上数字的3次幂之和等于数字它本身. 水仙花数是自幂数的一种,三位的三次自幂数才叫 ...
- Cassandra 数据一致性
基本概念 一致性: 在分布式系统中的所有数据备份,在同一时刻是否同样的值 QUORUM: 是一个可以计算的数字,对数据一致性起重要作用 Node: 主要用来存储数据 Data Center: 数据中心 ...
- VSCode编辑器用户设置
{"gitlens.advanced.messages": {"suppressCommitHasNoPreviousCommitWarning": false ...
- java+struts上传文件夹文件
这里只写后端的代码,基本的思想就是,前端将文件分片,然后每次访问上传接口的时候,向后端传入参数:当前为第几块文件,和分片总数 下面直接贴代码吧,一些难懂的我大部分都加上注释了: 上传文件实体类: 看得 ...
- POJ 2528 Mayor’s posters (线段树段替换 && 离散化)
题意 : 在墙上贴海报, n(n<=10000)个人依次贴海报,给出每张海报所贴的范围li,ri(1<=li<=ri<=10000000).求出最后还能看见多少张海报. 分析 ...