`
wbj0110
  • 浏览: 1602773 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

rebase

阅读更多

假设你现在基于远程分支"origin",创建一个叫"mywork"的分支。

$ git checkout -b mywork origin

现在我们在这个分支做一些修改,然后生成两个提交(commit).

$ vi file.txt
$ git commit
$ vi otherfile.txt
$ git commit
...

但是与此同时,有些人也在"origin"分支上做了一些修改并且做了提交了. 这就意味着"origin"和"mywork"这两个分支各自"前进"了,它们之间"分叉"了。

在这里,你可以用"pull"命令把"origin"分支上的修改拉下来并且和你的修改合并; 结果看起来就像一个新的"合并的提交"(merge commit):

但是,如果你想让"mywork"分支历史看起来像没有经过任何合并一样,你也许可以用 git rebase:

$ git checkout mywork
$ git rebase origin

这些命令会把你的"mywork"分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把"mywork"分支更新 到最新的"origin"分支,最后把保存的这些补丁应用到"mywork"分支上。

当'mywork'分支更新之后,它会指向这些新创建的提交(commit),而那些老的提交会被丢弃。 如果运行垃圾收集命令(pruning garbage collection), 这些被丢弃的提交就会删除. (请查看 git gc)

现在我们可以看一下用合并(merge)和用rebase所产生的历史的区别:

在rebase的过程中,也许会出现冲突(conflict). 在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用"git-add"命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行:

$ git rebase --continue

这样git会继续应用(apply)余下的补丁。

在任何时候,你可以用--abort参数来终止rebase的行动,并且"mywork" 分支会回到rebase开始前的状态。

$ git rebase --abort

 

http://gitbook.liuhui998.com/4_3.html

 

分享到:
评论

相关推荐

    rebase.rar

    标题中的"rebase.rar"指的是一个压缩包文件,其中可能包含与“rebase”相关的工具或资料。在Windows操作系统中,“rebase.exe”通常是一个用于调整动态链接库(DLL)加载基址的实用程序,这有助于解决由于地址空间...

    Node.js-Rebase-editor一个专门用于Git交互式rebase的简单CLI应用

    **Node.js - Rebase-editor: 为Git交互式rebase打造的CLI工具** Git作为一款强大的版本控制系统,其丰富的功能让开发者在管理代码历史时有了极大的灵活性。在这些功能中,`git rebase` 是一个非常有用的命令,它...

    11. 高级 1: 不喜欢 merge 的分叉? 用 rebase 吧1

    Git 高级使用指南 - merge 和 rebase 的区别 在 Git 中,我们经常会遇到分叉的情况,特别是在多人协作时。当我们执行 `git merge` 命令时,commit 历史就会出现分叉,这种分叉再汇合的结构会让一些人觉得混乱而难以...

    sourceThree的使用-rebase的整个过程

    rebasee(变基)的上存方式是...我从网上查了很多资料,都没有记载很详细rebase在sourceThree是怎么用的一个过程,花了两天的时间研究一下,终于搞定了,当时连rebase是什么都不知道。 下面我会尽量的详细的说明白他。

    rebase重定位内存地址

    rebase 重定位内存地址;早版本vc自带,但vs2012等都不带了;网上很难找到的。

    Git 版本管理 9 分支冲突 (rebase) (教学 教程 tutorial)

    Git_版本管理_#9_分支冲突_(rebase)_(教学_教程_tutorial)

    git rebase 合并提交记录,学习代码

    在开发过程中,我们经常需要合并代码,而`git rebase`就是一种强大的工具,用于整理和优化提交历史,使其更加整洁。本文将深入探讨`git rebase`的原理和使用方法。 ### Git Rebase 基本概念 `git rebase`主要用于...

    Git的merge和rebase你真的了解吗?

    本文将深入探讨Git的两个关键功能——`merge`和`rebase`,以及它们在日常开发中的应用。 1. **Git的版本控制**:Git的核心功能是版本控制,它能够记录文件的每一次修改,包括修改的内容、作者和时间。这使得开发者...

    前端大厂最新面试题-git rebase_ git merge.docx

    git rebase 和 git merge 的理解与区别 Git 是一个版本控制系统,广泛应用于软件开发过程中。其中,git rebase 和 git merge 是两个常用的命令,都是用于合并分支,但是它们的实现机制和应用场景却有所不同。 git...

    基于Ruby的MKS rebase脚本 Ruby语言基础

    本主题“基于Ruby的MKS rebase脚本 Ruby语言基础”关注的是如何利用Ruby语言编写脚本来实现MKS(可能是指Mercurial或类似的版本控制系统)中的文件重定位功能,即rebase操作。 首先,我们需要理解MKS rebase的基本...

    git 推送分支和变基rebase操作

    在 Git 中,`push` 和 `rebase` 是两个关键的操作,用于协同开发和维护代码库。本文将深入探讨这两个概念以及它们在不同场景下的应用。 首先,`git push` 是将本地分支的更改推送到远程仓库的过程。通常,我们遵循...

    git rebase 将提交点放置在一条直线上,提交点根据合并时间排序

    git rebase 命令可以将提交点放置在一条直线上,并根据提交时间进行排序。这是 git rebase 的一个常见用途。 当使用 git rebase 时,Git 会从指定的提交开始,重新应用后续的提交。这样可以将一系列提交重新排列,形成...

    一不小心git rebase后出现(master|REBASE 1/10)的问题及解决办法

    5. **终止rebase**:如果你发现rebase过程出错,或者想要完全放弃rebase操作,可以使用 `git rebase --abort` 来取消当前的rebase,这将恢复到rebase前的状态。 在描述中提到的错误情况,用户在尝试 `git push` 时...

    Python库 | rebase-1.0.4-py3-none-any.whl

    **Python库 rebase-1.0.4-py3-none-any.whl** 在Python的世界里,库是开发者的重要工具,它们提供了丰富的功能,使我们能够更高效地编写代码。`rebase`是一个这样的库,版本号为1.0.4,专为Python 3设计,适用于...

    git rebase 成功之后撤销的操作方法

    然而,不当使用`git rebase`可能会导致问题,特别是当你已经完成了一个rebase操作后,可能需要知道如何撤销它。本文将详细介绍在`git rebase`成功后如何恢复到rebase前的状态。 `git rebase`的主要功能是将一个分支...

    Sungq1990#blog#git rebase操作1

    merge主要发生在这样几个地方1 两个人同时开发一个分支,在拉取对方代码的时候2 要将代码合并到master的时候git pull origin master

    vscode-git-rebase:⌥VSCode扩展,可使用热键快速设置交互式git rebase的操作

    Git Rebase(Visual Studio代码扩展) 使用键盘快捷键可以快速编辑交互式Git基准库的操作。 如何使用 按下与您所需的git rebase操作相对应的键。 此命令将应用于所有选定的行。 键盘快捷键: p将命令设置为“ ...

    git-rebase-reword:修改任何git commit不仅要持续

    git-rebase-reword git-rebase-reword是一个简单的git命令,以与修改相同的方式来更改一个提交(最后一个或更旧的提交) 文献资料 它是基于对rebase交互操作的名称来命名的,以补充提交“ reword”。 参见和 -...

    10高级 1:不喜欢 merge 的分叉?用 rebase 吧(1).md

    用 rebase 吧 学习时长: 4分20秒 12 高级 2:刚刚提交的代码,发现写错了怎么办? 学习时长: 1分56秒 13 高级 3:写错的不是最新的提交,而是倒数第二个? 学习时长: 6分32秒 14 高级 4:比错还错,想直接丢弃刚写的...

Global site tag (gtag.js) - Google Analytics