- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我最近开始使用 git rebase
并且不是 100% 确定我做对了。为了题主的缘故,origin中有两个分支,master
和从master
分支出来的next
。
自上次两者同步以来,master
有 2 次提交,next
有 6 次:
$ git log --oneline origin/next..origin/master
59b5552 master commit #2
485a811 master commit #1
$ git log --oneline origin/master..origin/next
4ebf401 next commit #6
e9b6586 next commit #5
197ada0 next commit #4
4a2c3c6 next commit #3
040a055 next commit #2
84537bf next commit #1
当我 checkout next
并执行 git rebase -i origin/master
时,我得到以下信息:
$ git status
# On branch next
# Your branch and 'origin/next' have diverged,
# and have 8 and 6 different commits each, respectively.
最后在执行 git pull --rebase
之后,来自 master
的两个提交在 next
中:
$ git log --oneline origin/next..next
8741d09 master commit #2
485a811 master commit #1
问题:
pull --rebase
之前会有 8 和 6
次不同的提交?感激不尽:)
最佳答案
让我们从头开始。这是您的原始状态图:
A-B-C (master, origin/master) \ D-E-F-G-H-I (next, origin/next)
当您 checkout 时 next
并重新定位 next
到 origin/master
,它在 origin/master
上的两个提交之后创建了 6 个新提交.这些新提交将“master commit #2”(我图中的 C
)作为它们的祖先,而不是它们的原始祖先 origin/master
和 origin/next
发散(在我的图表中为 A
),因此它们的哈希值将不同。我相信这就是为什么你会看到 next
有 8 个来自 origin/next
的不同提交: 来自 origin/master
的 2以及 origin/next
上的 6 个“重新哈希”提交.
在 git checkout next ; git rebase -i origin/master
之后,你应该有这个:
A-B-C (master, origin/master) \ \ \ D'-E'-F'-G'-H'-I' (next) \ D-E-F-G-H-I (origin/next)
你可以看到next
确实有 8 个提交不在 origin/next
上, 和 origin/next
确实有 6 个提交不在 next
上.当然,这只是根据提交的 SHA-1 哈希值。如果您git diff origin/next next
,实际内容应该非常接近。 -- diff 应该只显示来自 B
的变化和 C
(如图中标记)。
当你做 git pull --rebase
同时仍在 next
,它从源(远程 origin/next
)获取更改并将当前分支(next
) rebase 到该远程。这会导致 next
中的更改但不 origin/next
在 origin/next
之后出现关于新next
分支。它应该看起来像这样:
A-B-C (master, origin/master) \ D-E-F-G-H-I (origin/next) \ B'-C' (next)
如果这就是您希望历史图表看起来的样子,那么您就成功了。
但是,我怀疑您真的想让事情看起来像中间的图表,尤其是如果 next
是一个功能分支,您将在其中处理项目的下一部分,并且 master
用于稳定代码和小错误修复。如果是这样,那么你应该完成 git push
而不是 git pull --rebase
让 Remote 反射(reflect)您的历史版本,而不是相反。
关于git rebase 基础知识,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11563319/
积累和总结,是长期持续的过程 01 最近,很多朋友微信私聊关于「 butte-java-note 」仓库的话题; 这个「 Git仓库 」每年都会
我即将参加挑战测试,所以我不必参加数据库处理类(class)。尽管在过去的 5 年里我一直在使用数据库,但我还是忍不住对测试感到紧张。这是 50 个问题,有 2 部分:真/假部分和我实际编写 SQL
我的 groovy 代码将 Rabbit Native Plugin 用于 grails: def handleMessage(def body, MessageContext context) {
我想看看是否有人可以就我在 .NET 环境中的进一步知识提供任何建议... 这里有一点背景。我上了一所大学并获得了计算机科学学士学位(主要从事 C、Java 和 C++ 方面的工作)。大学毕业后在一家
我在 postgres 数据库中有一个表,该表用于测试环境,我们需要一次添加和删除多个列。问题是 postgres 最多有 1600 列,并且这个计数包括丢弃的列。我的表永远不会有 1600 个“未丢
作为业余程序员 3 年(主要是 Python 和 C)并且从未编写过超过 500 行代码的应用程序,我发现自己面临两个选择: (1) 学习数据结构和算法设计的基本知识,使我成为一名 l33t 计算机科
有人能告诉我为什么 Android 工作需要 Linux 知识吗?许多 Android 工作都以 Linux 作为先决条件。我可以很好地从 Windows 机器开发 Android 应用程序吗? 最佳
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
是否可以在 Drools 中保持知识 session ?如果是这样,如何? 我将事实存储在数据库中,并且每次添加新事实时,我都希望避免在新 session 中重新加载所有事实。 目前,当有新事实时,该
我对 C++ 有很好的了解,但从未深入研究 STL。我必须学习 STL 的哪一部分才能提高工作效率并减少工作中的缺陷? 谢谢。 最佳答案 I have good knowledge of C++ 恕我
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 年前。 Improve
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
在我从 SO answers here 和许多 BackBoneJs 示例中选择的示例之一中,我看到初始化函数知道模型将使用哪个 View 进行渲染。我不知道我现在有点偏见,这是一个好的做法还是取决于
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 12 年前。 Improve thi
我在我的网站上使用 C# 和 ASP.NET MVC 3 实现 OpenID 和 OAuth。我基于 DotNetOpenAuth用于后端和openid-selector对于前端。 我喜欢 openi
很长一段时间以来,我都在思考和研究C语言编译器以汇编形式的输出,以及CPU架构。我知道这对你来说可能很愚蠢,但在我看来有些东西是非常无效的。如果我错了,请不要生气,我不明白所有这些原则是有原因的。如果
我有一些 Python 知识,但我从来不认为自己对这门语言特别流利。我正在开发一个潜在的机器视觉项目,该项目将从 SimpleCV 中受益匪浅,但从时间的角度来看,我宁愿不必非常流利地使用 pytho
我是一名优秀的程序员,十分优秀!