git stash 你真的理解正确了吗?

git stash 保存当前工作区和暂存区进度,回退到上一个 git commit 之后的状态
git stash save 'msg' 添加注释
git stash list 显示保存的列表
git stash pop 恢复最新的进度到工作区
git stash pop stash@{1} 恢复指定的保存列表到工作区(通过 git stash list 得到 stash@{1})
git stash clear 删除所有保存的工作进度

总结:
git stash 会将当前修改保存(默认只会保存加入到版本管理的文件,Untracked 文件不会存储),然后将当前工作区恢复到最近的一次提交,在此干净的基础上可以做其它工作,最后将工作区修改恢复

注意:恢复工作区修改,不是完全恢复到保存时候的状态,只是将修改恢复,在 stash 保存之后做的工作仍将保留



使用场景:

场景一:

先弄清楚几个事情:

  1. 线上用 master 分支
  2. 开发用 dev 分支
  3. bug 修复用 bugfix 分支(该分支可以不存在)

假如现在只有一个 master 分支,并且开发也是在 master 上(哦,糟糕的分支职责划分),
线上发生一个紧急bug 需要修复,又不想将目前的修改和bug 修复一块提交

传统方式:新建分支,在新分支上拉取 master 最新代码并修复,然后合并到 master 推送

解决: 使用 stash
git stash 保存当前修改
...bug 修复提交
git stash pop 恢复修改,继续工作
方便在于不用为了避免当前修改工作而另外建立分支

问题来了:
问题一: git stash pop 之后, bugfix 的内容还存在吗?
答: 存在
问题二: bugfix 和我们保存之前的修改冲突了怎么办?
答: 和 git merge 一样,会自动 merge, 并提示发生了冲突


image.png

场景二:

还是上面那个例子,只不过现在开发是在 dev 分支上

我们知道,dev 分支上有修改未提交,我们是不能切换到 别的分支上的,不管是 master 分支上还是 bugfix 分支上,一般情况下,我们需要提交 dev 分支上的修改再切换,那么 dev 分支上多了一次无畏的提交记录,如果不想加一次不必要的提交呢?

解决:用 git stash 保存当前修改,那么 dev 分支状态回退到 最近的一次提交,就是说这个时候 dev 分支是没有发生变化的(变化被保存到 stash 里了),那么就可以立刻切换分支
在 master 或 bugfix 分支上解决完 bug 后,就可以切换回 dev 分支,用 git stash pop 恢复之前的修改,继续工作。

总结:
git stash 之后,版本库状态会恢复到最近的一次提交完的状态
git stash 之后,做的修改,在 git stash pop 之后,仍然会保留,合并当前状态和 stash 状态,有冲突会默认 merge, 并提示冲突文件
git stash 默认只会保存已经加入到版本管理的文件

再说一句:
假如 A 文件已经被加入版本库,做以下操作:
git stash 保存
删除 A 文件
git stash pop 之后, A 文件是被删除掉的,不会再显示出来

也就是说,最终的状态是 pop 出来的状态和当前状态的合并(merge)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,723评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,080评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,604评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,440评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,431评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,499评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,893评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,541评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,751评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,547评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,619评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,320评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,890评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,896评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,137评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,796评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,335评论 2 342

推荐阅读更多精彩内容

  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 13,626评论 9 163
  • 安装Git Git的下载地址:Git官网下载地址 Git本地仓库和命令 配置用户 下载完Git后,右键会有一个Gi...
    TokyoZ阅读 4,485评论 1 7
  • 声明:这篇文章来源于廖雪峰老师的官方网站,我仅仅是作为学习之用 Git简介 Git是什么? Git是目前世界上最先...
    横渡阅读 3,941评论 3 27
  • Git 是目前最流行的分布式版本控制系统之一。 版本控制指的是,记录每次版本变更的内容和时间等细节,保留各版本之间...
    神齐阅读 1,396评论 0 7
  • 分支管理 分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习...
    bo_song阅读 705评论 0 1