回顾:[Git] 017 加一条分支,享双倍快乐 的 "2.3"

1. "Fast-forward"

  • "Git" 在合并分支时会尽可能地使用 "Fast-forward"
  • "Fast-forward" 这种模式会使得删除分支后丢失该分支的信息

1.1 丢失的信息

  • 目前的情况

  • 删除 "conflict" 分支

  • 找茬时间

  • 上图只展示了一部分

1.2 我打个不大恰当的比喻

  • 如果

    • 把非 "master" 分支看作“表演者”
    • 把 "master" 分支看作“观众”
  • 那么
    • “表演结束”(删除分支)后
    • 留给“观众”的是“台上一分钟”(最后一次 "commit" 的内容)
    • 而“台下十年功”(除最后一次以外所有 "commit" 的内容),“观众”是看不到的

2. 如何让“观众”看到“表演者”的“台下十年功”?

2.1 “记者”——"merge" 的参数 "--no-ff" 还在赶来的路上

  • 创建并切至分支

  • 修改 "note_01.txt"

  • 添加并提交

  • 切回 "master" 分支

2.2 有请 "--no-ff" 闪亮登场

  • "--no-ff"

    • 我的出场,意味着禁用 "Fast-forward"
    • 作为一个“记者”,合并这样的事当然要记作一次 "commit",所以用 "-m" 加一句“注释”

2.3 查看一下分支历史

分析

  • 其实上图有三次合并历史
  • 我截了张 "reflog" 的图

  • 这里再次说明了 "Fast-forward" 这种模式会使得删除分支后丢失该分支的信息
  • 加上"--no-ff" 参数合并后能看出来曾经做过合并
  • "Fast-forward" 合并看不出来曾经做过合并
  • 使用 "--no-ff" 参数合并后删除分支,仍能看出来

3. 补充:分支策略

  • 在实际开发过程中

    • "master" 分支需要非常稳定,仅用来发布新版本,平时不在上面干活
    • "dev" 分支并不稳定,因为平时在这里干活
    • 如果要发布新版本,就把 "dev" 分支合并到 "master" 分支上
    • 可能许多人都是从 "dev" 分支上再开一个分支干活;干完活后往 "dev" 分支上合并
  • 示意图

  • 莫名地想到节点电压。。。

[Git] 019 merge 命令的补充的更多相关文章

  1. [Git] 024 log 命令的补充

    0. 回顾 [Git] 009 逆转未来 的 "1" 画张导图 其实 --oneline 前有个"关键字参数" "--pretty" --o ...

  2. [Git] 026 config 命令的补充

    少废话,上例子 1. 让命令更醒目 $ git config --global color.ui true 2. 偷懒 $ git config --global alias.st status 使用 ...

  3. [Git] 012 rm 命令的补充

    0. 前言 [Git] 007 三棵树以及向本地仓库加入第一个文件 的 "2.5" 有提及 git rm --cached <file> 1. 介绍 git rm &l ...

  4. Git中的merge命令实现和工作方式

    想象一下有例如以下情形:代码库中存在两个分支,而且每一个分支都进行了改动.最后你想要将当中的一个分支合并到其它的分支中.个人博客网址 http://swinghu.github.com/ 那么要问合并 ...

  5. Git中的merge命令实现中出现问题及其解决

    Git中的merge命令实现和工作方式 2015年8月17日星期一 丹丹 git代码在合并两个分支的时候总是会出现一下的错误提示,不能正常的完成合并分支,错误提示如图所示: 但是在其他的终端是可以完成 ...

  6. Git合并分支命令:git merge --ff

    今天研究了一下git merge命令常用参数,并分别用简单的例子实验了一下,整理如下: 输入git merge -h可以查看相关参数: --ff  快速合并,这个是默认的参数.如果合并过程出现冲突,G ...

  7. Git合并分支命令参数详解:git merge --ff

    今天研究了一下git merge命令常用参数,并分别用简单的例子实验了一下,整理如下: 输入命令git merge -h可以查看相关参数: --ff  快速合并,这个是默认的参数.如果合并过程出现冲突 ...

  8. git merge 命令的使用

    我们把dev分支的工作成果合并到master分支上: $ git merge dev Updating d46f35e..b17d20e Fast-forward readme.txt | 1 + 1 ...

  9. [Git] 008 status 与 commit 命令的补充

    本文的"剧情"承接 [Git] 007 三棵树以及向本地仓库加入第一个文件 1. 对 "status" 的补充 1.1 "status" 有 ...

随机推荐

  1. 移动UI控件Telerik UI for Xamarin发布R2 2019|引入Map控件

    Telerik UI for Xamarin是一个构建跨平台移动应用程序的原生UI.Telerik UI for Xamarin使用Xamarin.Forms技术,它可以让开发人员从一个单一的共享C# ...

  2. js 传递字符串问题

    data[i]['operate'] = '<a onclick="objProjectStageEdit.onProjectStageEdit(' + scheduleID + ', ...

  3. 《Head First 软件开发》阅读五

    结束开发循环:娟娟细流归大海 几乎完成了任务,而开发循环结束所要面对的问题是用户测试的安排.新的一轮重构和重新设计. 开发循环已经完成,但是还是有很多事情可以去做.系统测试必不可少,但是是由谁来做系统 ...

  4. 【NOIP2017提高组模拟12.10】神炎皇

    题目 神炎皇乌利亚很喜欢数对,他想找到神奇的数对. 对于一个整数对(a,b),若满足a+b<=n且a+b是ab的因子,则成为神奇的数对.请问这样的数对共有多少呢? 分析 设\(gcd(a,b)= ...

  5. 私有ip地址知多少?

    1.私有ip的由来 在现在的网络中,ip地址分为公网ip地址和私有ip地址.公网ip是在Internet中使用的ip地址,而私有ip地址是在局域网中使用,在Internet上不使用. 由于我们目前使用 ...

  6. 结合webpack使用vue-router

    demo结构 webpack.config.js var path = require('path'); // const { VueLoaderPlugin } = require('vue-loa ...

  7. Mysql5.7.26解压版(免安装版)简单快速配置步骤,5分钟搞定(win10-64位系统)

    第一次安装mysql环境的时候,总会遇到各种各样的坑,在尝试了安装版和解压版的数据库之后,感觉mysql的解压版更加的简单方便,省去好多时间做专业的事情 我这里选择的是5.7.26版本,解压版下载地址 ...

  8. XML 属性

    XML 属性 从 HTML,你会回忆起这个:<img src="computer.gif">."src" 属性提供有关 <img> 元素 ...

  9. 完美解决safari、微信浏览器下拉回弹效果。

    完美解决safari.微信浏览器下拉回弹效果,只保留局部回弹效果. CSS代码 .box{ overflow: auto; -webkit-overflow-scrolling: touch; } H ...

  10. sh_10_体验模块

    sh_10_体验模块 import sh_10_分隔线模块 sh_10_分隔线模块.print_line("-", 50) print(sh_10_分隔线模块.name)