你真的会使用 git 吗?你能回答下面几个问题吗?

有三个commit(顺序:CommitA、CommitB、CommitC),它们相互独立,没有依赖。

  1. 在不修改B、C的前提下,修改A,怎么操作?
  2. 合并A、B、C为一个commit,怎么操作?
  3. 调整A、B、C的顺序编程 C、B、A,怎么操作?

作为一个开发,日常工作中不可避免的要使用 git。

当然了,如果你技术无敌、独立承担一个项目、没人干预或者影响你的工作,那么你可能不需要下面这些总结。哈哈哈...

由于 xxx 原因,我认为应该给项目组的其他人讲讲 git。

因为语言障碍和技术熟练度的障碍,为了让同事们更好地理解并且愿意使用 git 。我不得不一个场景一个方法地讲解,所以有了下面总结。

这难道不是一种成长吗?

场景1

J 写了一个功能,分成3次commit(顺序:CommitA、CommitB、CommitC)。完成功能之后,他找了B先生进行Code Review,B先生觉得 CommitB 和 CommitC 没有问题,CommitA需要进行简单修改。

那么如何在不改变CommitB和CommitC的前提下,修改CommitA呢?

方法:

使用 git rebase -i,操作如下

  1. rebase CommitA、CommitB、CommitC 三个commit
$ git rebase -i <parent commit of A>
  1. 修改 CommitA

    (1)Commit A前面pick修改为edit,然后:wq保存退出。

(2)这是HEAD停留在CommitA,可以对CommitA进行修改,然后使用下面命令覆盖CommitA

$ git add <修改文件>
$ git commit -amend
  1. 让git完成后续rebase操作
$ git rebase -continue

场景2

J修改了CommitA后,项目leader希望一个功能尽可能使用一个commit提交。

那么如何合并CommitA、CommitB、CommitC为一个commit呢?

方法:

同样使用 git rebase -i,操作如下

  1. rebase CommitA、CommitB、CommitC 三个commit
$ git rebase -i <parent commit of A>
  1. 合并 Commits

    (1)CommitB和CommitC前面pick修改为squash,然后:wq保存退出。

(2)这时,我们会需要重新编辑 commit message,统合3条commit的信息。然后:wq保存退出。

3. 让git完成后续rebase操作

$ git rebase -continue

场景3

J 合并CommitA、CommitB、CommitC后,新产生的CommitA+需要将代码更新到master上。但是,同一项目组的T已经提交了CommitD。

本来 J 只需要merge自己的CommitA+到master就可以了,但是 J 下一个任务依赖于 T 提交的CommitD。

J 希望一次性更新master和自己的branch(branch_J_dev),一石二鸟。

那么如何在merge自己的CommitA+到master的同时将CommitD也merge到自己的branch(branch_J_dev)中呢?

方法:

又是使用 git rebase,操作如下

  1. rebase 自己的branch_J_dev 到 master
$ git checkout branch_J_dev
$ git rebase --onto master <CommitA+>
  1. master 合并 branch_J_dev 的提交
$ git checkout master
$ git merge branch_J_dev

git checkout mastergit merge branch_J_dev 非常重要,网络上大部分教程都没有最后一步。

而且好多人都把命令写成了git rebase --ontomaster <commit id>全是抄袭同一个人的,也是醉了。哈哈哈哈...

我也是因为被坑了,所以才查了一下一下资料,发现竟然还需要一步。

场景4(需求基本和场景3一致)

如何 J 本次希望提交的代码有CommitA+、CommitB+、CommitC+三次commit(顺序:CommitA+、CommitB+、CommitC+)。

那么如何在merge自己的CommitA+、CommitB+、CommitC+到master的同时将CommitD也merge到自己的branch(branch_J_dev)中呢?

方法:

基本和场景3一致,操作如下

  1. rebase 自己的branch_J_dev 到 master
$ git checkout branch_J_dev
$ git rebase --onto master <CommitA+>^
  1. CommitA 合并进master
$ git checkout master
$ git merge branch_J_dev

^代表,起点。<CommitA+>^表示CommitA为起点后面所有的Commit。

场景5

如何修改 commit 记录(调整顺序+修改message)?

其实这种操作没什么意义,但是对于对 commit log 有强迫症的人,或许有想修改 commit 记录的冲动。

哈哈哈哈...

方法:

还是使用 git rebase。惊喜不惊喜?意外不意外?操作如下

  1. rebase CommitD和CommitA+
$ git rebase -i <parent commit of D>
  1. 调整 commit 顺序,就是将 CommitD 和 CommitA+ 顺序进行调整。
  2. 修改 message ,将 pick 修改为reword
  3. 让git完成后续rebase操作
$ git rebase --continue

(最后)小提示

  1. 如果想中途取消rebase操作,后悔药

    分享几个 git 的使用场景的更多相关文章

    1. 分享一篇 Git Web 开发流程

      分享一篇 Git Web 开发流程 web 项目如何进行 git 多人协作开发 https://segmentfault.com/a/1190000018165757

    2. 常用的 Git 命令与场景

      Git 分布式版本控制系统 它拥有完整的版本控制功能,能够解决多人协作的问题 将自己的代码同步到 Github 上能够提升开发效率 git 会记录你每一次的版本修改操作 常用的 Git 操作 # 指定 ...

    3. Git典型使用场景

      1. 在本地创建版本库(把本地的一个目录内的文件纳入版本库管理,方便查看变动历史,恢复版本等.不限于代码,可以是笔记等所有需要追踪历史的文件.) git init -- 把当前目录初始化为版本库 2. ...

    4. android studio怎么分享项目到Git@OSC托管

      鄙人初次发表,如有不妥之处,敬请批评指正 1,安装git. git下载地址:http://git-scm.com/downloads/ 2,在AS 的File->Settings->Ver ...

    5. 分享如何将git项目导入GitHub(附创建分支)

      前言:我们应该很多都会有自己的私有项目,大多情况都是存放在自己的硬盘中,今天我分享一下怎么讲自己的私有项目更新到GitHub上,这样再也不用担心项目丢失了. 一:下载git 下载链接git链接,根据自 ...

    6. git 回退各种场景操作

      在git的一般使用中,如果发现错误的将不想提交的文件add进入index之后,想回退取消,则可以使用命令:git reset HEAD <file>...,同时git add完毕之后,gi ...

    7. idea中git常见使用场景

      工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程Git仓库上获取项目源码 场景三:小 ...

    8. TOP100summit:【分享实录-华为】微服务场景下的性能提升最佳实践

      本篇文章内容来自2016年TOP100summit华为架构部资深架构师王启军的案例分享.编辑:Cynthia 王启军:华为架构部资深架构师.负责华为的云化.微服务架构推进落地,前后参与了华为手机祥云4 ...

    9. IDEA中Git的应用场景

      工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程git仓库上获取项目源码 场景三:小 ...

    随机推荐

    1. Linux与堆栈概念

      在学习C/C++编程的时候,老师都会反复灌输一些概念.比如程序内变量在堆栈上的分配,栈是由高地址到低地址,堆是由低地址到高地址等等,然后画出这样一幅经典概念图: 图片来自:http://blog.cs ...

    2. java内存模型7-处理器内存模型

      处理器内存模型 顺序一致性内存模型是一个理论参考模型,JMM和处理器内存模型在设计时通常会把顺序一致性内存模型作为参照.JMM和处理器内存模型在设计时会对顺序一致性模型做一些放松,因为如果完全按照顺序 ...

    3. 网际报文控制协议ICMP

      为了更有效地转发IP数据报和提高交付成功的机会,在网际层使用了网际控制报文协议ICMP.ICMP允许主机或路由器报告差错情况和提供有关异常情况的报告.ICMP是因特网的标准协议.但ICMP不是高层协议 ...

    4. GreenDao 使用二

      1.创建一个实体类 1 Entity note = schema.addEntity("Note"); 默认表名就是类名,也可以自定义表名 1.dao.setTableName(& ...

    5. Java图书管理系统(用Java常用集合实现)

      图书管理系统 一.需求说明 1.功能:登录,注册,忘记密码,管理员管理,图书管理. 2.管理员管理:管理员的增删改查. 3.图书管理:图书的增删改查. 4.管理员属性包括:id,姓名,性别,年龄,家庭 ...

    6. 开涛spring3(4.1) - 资源 之 4.1 基础知识

      4.1.1  概述 在日常程序开发中,处理外部资源是很繁琐的事情,我们可能需要处理URL资源.File资源资源.ClassPath相关资源.服务器相关资源 (JBoss AS 5.x上的VFS资源)等 ...

    7. org.hibernate.LazyInitializationException...no session or session was closed

      org.hibernate.LazyInitializationException:failed to lazily initialize a collection of role:cn.its.oa ...

    8. 在wamp下使用netbeans开启Xdbug

      1.到http://www.xdebug.org 下载与PHP对应的xdebug版本,也可以把phpinfo源码粘贴到http://www.xdebug.org/find-binary.php,提交后 ...

    9. php-fpm 与 fastCgi的浅谈

      首先,CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的,方便CGI程序的编写者. web server(比如说nginx)只是内容的分发者.比如,如果请求/index.h ...

    10. 数据挖掘应用案例:RFM模型分析与客户细分(转)

      正好刚帮某电信行业完成一个数据挖掘工作,其中的RFM模型还是有一定代表性,就再把数据挖掘RFM模型的建模思路细节与大家分享一下吧!手机充值业务是一项主要电信业务形式,客户的充值行为记录正好满足RFM模 ...