分享几个 git 的使用场景
你真的会使用 git 吗?你能回答下面几个问题吗?
有三个commit(顺序:CommitA、CommitB、CommitC),它们相互独立,没有依赖。
- 在不修改B、C的前提下,修改A,怎么操作?
- 合并A、B、C为一个commit,怎么操作?
- 调整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,操作如下
- rebase CommitA、CommitB、CommitC 三个commit
$ git rebase -i <parent commit of A>
- 修改 CommitA
(1)Commit A前面pick修改为edit
,然后:wq
保存退出。
(2)这是HEAD停留在CommitA,可以对CommitA进行修改,然后使用下面命令覆盖CommitA
$ git add <修改文件>
$ git commit -amend
- 让git完成后续rebase操作
$ git rebase -continue
场景2
J修改了CommitA后,项目leader希望一个功能尽可能使用一个commit提交。
那么如何合并CommitA、CommitB、CommitC为一个commit呢?
方法:
同样使用 git rebase -i,操作如下
- rebase CommitA、CommitB、CommitC 三个commit
$ git rebase -i <parent commit of A>
- 合并 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,操作如下
- rebase 自己的
branch_J_dev
到 master
$ git checkout branch_J_dev
$ git rebase --onto master <CommitA+>
master
合并 branch_J_dev 的提交
$ git checkout master
$ git merge branch_J_dev
git checkout master
和git 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一致,操作如下
- rebase 自己的
branch_J_dev
到 master
$ git checkout branch_J_dev
$ git rebase --onto master <CommitA+>^
- CommitA 合并进
master
$ git checkout master
$ git merge branch_J_dev
^
代表,起点。<CommitA+>^
表示CommitA为起点后面所有的Commit。
场景5
如何修改 commit 记录(调整顺序+修改message)?
其实这种操作没什么意义,但是对于对 commit log 有强迫症的人,或许有想修改 commit 记录的冲动。
哈哈哈哈...
方法:
还是使用 git rebase。惊喜不惊喜?意外不意外?操作如下
- rebase CommitD和CommitA+
$ git rebase -i <parent commit of D>
- 调整 commit 顺序,就是将 CommitD 和 CommitA+ 顺序进行调整。
- 修改 message ,将 pick 修改为
reword
。 - 让git完成后续rebase操作
$ git rebase --continue
(最后)小提示
- 如果想中途取消rebase操作,后悔药
分享几个 git 的使用场景的更多相关文章
- 分享一篇 Git Web 开发流程
分享一篇 Git Web 开发流程 web 项目如何进行 git 多人协作开发 https://segmentfault.com/a/1190000018165757
- 常用的 Git 命令与场景
Git 分布式版本控制系统 它拥有完整的版本控制功能,能够解决多人协作的问题 将自己的代码同步到 Github 上能够提升开发效率 git 会记录你每一次的版本修改操作 常用的 Git 操作 # 指定 ...
- Git典型使用场景
1. 在本地创建版本库(把本地的一个目录内的文件纳入版本库管理,方便查看变动历史,恢复版本等.不限于代码,可以是笔记等所有需要追踪历史的文件.) git init -- 把当前目录初始化为版本库 2. ...
- android studio怎么分享项目到Git@OSC托管
鄙人初次发表,如有不妥之处,敬请批评指正 1,安装git. git下载地址:http://git-scm.com/downloads/ 2,在AS 的File->Settings->Ver ...
- 分享如何将git项目导入GitHub(附创建分支)
前言:我们应该很多都会有自己的私有项目,大多情况都是存放在自己的硬盘中,今天我分享一下怎么讲自己的私有项目更新到GitHub上,这样再也不用担心项目丢失了. 一:下载git 下载链接git链接,根据自 ...
- git 回退各种场景操作
在git的一般使用中,如果发现错误的将不想提交的文件add进入index之后,想回退取消,则可以使用命令:git reset HEAD <file>...,同时git add完毕之后,gi ...
- idea中git常见使用场景
工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程Git仓库上获取项目源码 场景三:小 ...
- TOP100summit:【分享实录-华为】微服务场景下的性能提升最佳实践
本篇文章内容来自2016年TOP100summit华为架构部资深架构师王启军的案例分享.编辑:Cynthia 王启军:华为架构部资深架构师.负责华为的云化.微服务架构推进落地,前后参与了华为手机祥云4 ...
- IDEA中Git的应用场景
工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程git仓库上获取项目源码 场景三:小 ...
随机推荐
- C#中对于变量的声明和初始化
C#变量初始化是C#强调安全性的另一个例子.简单地说,C#编译器需要用某个初始值对变量进行初始化,之后才能在操作中引用该变量.大多数现代编译器把没有初始化标记为警告,但C#编译器把它当作错误来看待. ...
- 无分类编址(CIDR)构成超网
CIDR(无分类域间路由选择) CIDR最主要有两个以下特点: 消除传统的A,B,C地址和划分子网的概念,更有效的分配IPv4的地址空间,CIDR使IP地址又回到无分类的两级编码.记法:IP地址::= ...
- wifi驱动总结(1)
一.wifi平台设备驱动注册过程Path:Rtw_android.c (rk3399\kernel\drivers\net\wireless\rockchip_wlan\rtl8723au\os_de ...
- kali虚拟机安装提示安装系统步骤失败
首先虚拟机不论是VM还是VirtualBox都可以直接安装kali镜像文件的,不过如果你采用虚拟机默认硬盘8G设置的话,到的系统安装步骤会出错无法继续,具体原因不明. 解决办法却很简单,将虚拟机的硬盘 ...
- 你为什么必须(从现在开始就)掌握linux
写在前面 在我看来,人人都应该学习linux,但这不是本文探讨的重点.本文主要从软件测试人员的角度谈谈学习和掌握linux的重要性.必要性.紧迫性. 另外: 这里所说的linux系统,是unix系统和 ...
- ES6解构赋值详解
文章转载自:http://www.zhufengpeixun.cn/article/167 解构赋值(destructuring assignment)语法是一个 Javascript 表达式,这种语 ...
- JqueryEasyUI-从入门到精通-第一天
PS:本教程暂时不提供源码,自己动手写写会记得更牢固哦 Parser(解析器) 对象的属性和方法: 使用: 效果:
- “织梦”CMS注入高危漏洞情况
"织梦"CMS注入高危漏洞情况 作者: 时间:2014-04-17 "织梦"CMS是由上海卓卓网络科技有限公司研发的一款网站建站系统软件,又称&quo ...
- Tips_of_JS 之 利用JS实现水仙花数的寻找与实现斐波那契数列
一.水仙花数 1.啥是水仙花数? 水仙花数是指一个 n 位正整数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身.(例如:1^3 + 5^3+ 3^3 = 153) 2.利用JS实现对水 ...
- 移动端H5通用表单验证插件
将表单验证的通用部分提炼出来,做成一个简易插件,方便调用. 已将源码放到GitHub上,名字叫zValidate. 手机可扫描下图查看示例,PC端可点击此处查看: 一.原理 1)需要引入zepto.j ...
- 分享一篇 Git Web 开发流程