Java中的合并与重组(上)
通过优锐课核心java学习笔记中,我们可以看到,码了很多专业的相关知识, 分享给大家参考学习。
虽然在Git中合并和重组是相似的,但它们具有两种不同的功能。 要保持自己的历史记录整洁或完整,这是你应该知道的。
git rebase命令以其神奇的Git伏都教徒而闻名,初学者应该远离它,但是当谨慎使用时,它实际上可以使开发团队的生活变得更加轻松。 在本文中,我们将git rebase与相关的git merge命令进行比较,并确定所有将rebase纳入典型Git工作流程的潜在机会。
概念概述
了解git rebase的第一件事是它解决了与git merge相同的问题。 这两个命令都旨在将更改从一个分支集成到另一个分支,它们只是以非常不同的方式来进行更改。
考虑当你在专用分支中开始使用新功能时发生了什么,然后另一个团队成员使用新的提交更新主分支。 这导致了分叉的历史,对于使用Git作为协作工具的任何人都应该熟悉。
现在,假设master中的新提交与你正在使用的功能有关。 要将新提交合并到功能分支中,你有两种选择:合并或重新设置基础。
合并选项
最简单的方法是使用以下方法将主分支合并到功能分支中:
git checkout feature
git merge master
或者,你可以将其浓缩为单线:
git merge master feature
这会在功能分支中创建一个新的“合并提交”,将两个分支的历史联系在一起,从而为你提供一个如下所示的分支结构:

合并很好,因为它是一种无损操作。 现有分支不会以任何方式更改。 这避免了重新设置基准的所有潜在陷阱(如下所述)。
另一方面,这也意味着每次需要合并上游更改时,功能分支将具有无关的合并提交。 如果master非常活跃,这可能会污染功能分支的历史记录。 虽然可以通过高级git log选项缓解此问题,但其他开发人员可能很难理解该项目的历史记录。
变基选项
作为合并的替代方法,你可以使用以下命令将功能分支基于主分支:
git checkout feature
git rebase master
这会将整个功能分支移到主分支的顶端,从而有效地将所有新提交合并到主分支中。 但是,与其使用合并提交,不如通过为原始分支中的每个提交创建全新的提交来重新编制基础项目历史记录。
变基的主要好处是你可以获得更清晰的项目历史记录。 首先,它消除了git merge所需的不必要的合并提交。 其次,如你在上图中所看到的那样,重新定基也可以实现完美的线性项目历史记录-你可以一直沿功能的顶端一直到项目开始,而无需任何分叉。 使用git log,git bisect和gitk等命令可以更轻松地浏览项目。
但是,对于这个原始提交历史,有两个折衷:安全性和可追溯性。 如果你不遵循“变基础的黄金法则”,那么重写项目历史记录可能会对你的协作工作流程造成灾难性的影响。 而且,更不重要的是,重新定基会丢失合并提交所提供的上下文-你看不到何时将上游更改合并到功能中。
互动基础
交互式重定基础使你有机会在提交移至新分支时更改提交。 由于它可以完全控制分支的提交历史,因此它甚至比自动重新设置功能更强大。 通常,这用于在将功能分支合并到master之前清理混乱的历史记录。
要开始交互式重新基准化会话,请将i选项传递给git rebase命令:
git checkout feature
git rebase -i master
这将打开一个文本编辑器,列出所有将要移动的提交:
pick 33d5b7a Message for commit #1
pick 9480b3d Message for commit #2
pick 5c67e61 Message for commit #3
此清单准确定义了执行变基后分支的外观。 通过更改选择命令和/或重新排列条目的顺序,你可以使分支的历史记录看起来像你想要的任何东西。 例如,如果第二个提交解决了第一个提交中的一个小问题,则可以使用fixup命令将它们压缩为一个提交:
pick 33d5b7a Message for commit #1
fixup 9480b3d Message for commit #2
pick 5c67e61 Message for commit #3
当你保存并关闭文件时,Git将根据你的指示执行变基,从而产生类似于以下内容的项目历史记录:

消除这种微不足道的提交,可以使你功能的历史记录更容易理解。 这是git merge根本无法做到的事情。
扎根的黄金法则
一旦了解了什么是基础,最重要的事情就是什么时候不做基础。 git rebase的黄金法则是永远不要在公共分支上使用它。
例如,考虑如果你将母版重新基于功能分支会发生什么情况:

rebase将master中的所有提交移动到功能的尖端。 问题是这仅发生在你的存储库中。 所有其他开发人员仍在使用原始的master。 由于重新定基会带来全新的承诺,因此Git会认为你的分支机构的历史与其他人有所不同。
同步两个主分支的唯一方法是将它们重新合并在一起,从而产生一个额外的合并提交和两组包含相同更改的提交(原始更改和来自你的基于重新定义分支的更改)。 不用说,这是一个非常令人困惑的情况。
因此,在运行git rebase之前,请始终问自己:``还有其他人在看这个分支吗?'' 如果答案是肯定的,请放开键盘,然后开始考虑一种无损方式进行更改的方法(例如git revert命令)。 否则,你可以随意重写历史记录。

Java中的合并与重组(上)的更多相关文章
- Java中的合并与重组(下)
通过优锐课核心java学习笔记中,我们可以看到,码了很多专业的相关知识, 分享给大家参考学习. Java中的合并与重组上部分链接:https://www.cnblogs.com/youruike1/p ...
- Java中的集合框架(上)
Java中的集合框架概述 集合的概念: Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象. 集合的作用: 1.在类的内部,对数据进行组织: 2.简单的快速的搜索大数据量的 ...
- Java 中多态的实现(上)
Java 中语法上实现多态的方式分为两种:1. 重载.2. 重写,重载又称之为编译时的多态,重写则是运行时的多态. 那么底层究竟时如何实现多态的呢,通过阅读『深入理解 Java 虚拟机』这本书(后文所 ...
- JAVA中使用FTPClient实现文件上传下载
在JAVA程序中,经常需要和FTP打交道,比如向FTP服务器上传文件.下载文件,本文简单介绍如何利用jakarta commons中的FTPClient(在commons-net包中)实现上传下载文件 ...
- java中io流实现文件上传下载
新建io.jsp <%@ page language="java" contentType="text/html; charset=UTF-8" page ...
- JAVA中使用FTPClient实现文件上传下载实例代码
一.上传文件 原理就不介绍了,大家直接看代码吧 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 ...
- java中Error和Exception用法上有什么区别,Error是怎么回事?
顺便提一句, 和Exception 相对应的,还有Error,Error(错误)表示系统级的错误和程序不必处理的异常,是JRE(java运行环境)的内部错误或者硬件问题,比如,另外 某一处地方的bug ...
- hadoop中Text类 与 java中String类的区别
hadoop 中 的Text类与java中的String类感觉上用法是相似的,但两者在编码格式和访问方式上还是有些差别的,要说明这个问题,首先得了解几个概念: 字符集: 是一个系统支持的所有抽象字符的 ...
- Java中泛型的理解
Java中的泛型,本质上来说,就是是参数化类型,就是说所操作的数据类型被指定为一个参数,而不是确定的某种类型.这种数据类型可以用在类.接口和方法创建中.即泛型类.泛型接口.泛型方法.这样说可能不够生动 ...
随机推荐
- 基于selenium爬取京东
爬取iphone 注意:browser对象会发生变化,当对当前网页做任意操作时 import time from selenium import webdriver from selenium.web ...
- Codeforces I Wanna Be the Guy 题解
这道题非常简单,有两种做法: 1. 用一个数组标记是不是每个关卡小X或小Y都可以通过 2. 用set储存小X和小Y能够通过的关卡(set有去重功能),最后判断set的长度是否等于n 因为楼上已经有第一 ...
- Redis(四):del/unlink 命令源码解析
上一篇文章从根本上理解了set/get的处理过程,相当于理解了 增.改.查的过程,现在就差一个删了.本篇我们来看一下删除过程. 对于客户端来说,删除操作无需区分何种数据类型,只管进行 del 操作即可 ...
- 大叔 EF 来分析 EntityFrameworks.Data.Core 1
Common 1SQL命令拦截器主要实现EF的读写分离 SqlCommandInterceptor 继承父类DbCommandInterceptor 2SQL锁选项SqlLock 3忽略大小写,作为C ...
- Linux网络文件共享服务之smaba
一.SAMBA服务简介 samba是1991年由Andrew Tridgel开发实现,主要用于Windows和unix文件共享.samba实现了共享文件和打印,实现在线编辑,登录SAMBA用户的身份认 ...
- ①CM+CDH6.2.0安装(全网最全)
CM+CDH6.2.0环境准备 一 虚拟机及CentOs7配置 CentOS下载地址 master(16g+80g+2cpu+2核)+2台slave(8g+60g+2cpu+2核) 1.1 打开&qu ...
- CSS-01-引入css的三种方法
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- view 视图函数
一 Django的视图函数view 一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应. 响应可以是一张网页的HTML内容,一个重定向,一个404错 ...
- linux--->阿里云centos6.9安装yii2报错
阿里云centos6.9安装yii2报错 错误显示:Warning: require(/vendor/autoload.php): failed to open stream: No such fil ...
- docker相关----解决tomcat容器启动成功,无法访问的问题
使用docker安装了tomcat镜像,默认为latest最新的(8.5.50版本),依据tomcat镜像创建容器并同时做了端口映射 命令为:docker run --name tomcat01 -d ...