- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 git 的了解有限。
我已经从 master 创建了一个分支 B1,进行了一些编辑并提交到这个分支。
我想从 B1 创建另一个分支 B2,我在 B2 中进行了一些编辑
而且我还想提交 B2(包含 B2 和 B1 的编辑)并将其推送回 master
我该怎么做,文档假定您总是从 master 创建一个分支,而不是另一个分支。我为我的 git 愚蠢道歉。
最佳答案
tayfun 的回答基本上是正确的。如果您想了解更多有关原因的概念背景:
文档不应该对从 master 分支做出假设(至少如果你正在查看规范的 git 文档时不应该这样做;显然我不知道你在看什么文档)。示例通常可能从 master
开始,只是因为它们是简单的示例,但要理解的是:
master
没有什么特别的。
一个分支就是一个分支;其中一个刚好最先出现,按照惯例,它被称为 master
。
此外,git 没有“父分支”或类似内容的内存。在任何给定时间,您都可以专注于当前的提交拓扑。所以:
I have created a branch B1 from master, made some edits and committed to this branch.
x -- O <--(master)
\
A <--(B1)
I want to create another branch B2 from B1, I make some edits in B2
x -- O <--(master)
\
A <--(B1)
\
B <--(B2)
此时,git 不知道也不关心 B2
是“从 B1
创建的”。您可以不执行上述步骤,而是说:
B2
A
)B
)A
并创建分支B1
一切都会一样。
And I also want to commit and push B2 (with edits from B2 and B1) back to master
这里你的术语很困惑。
push
是更新远程仓库 ref。通常,您的 Remote 可能有一个分支对应于每个本地分支。尽管 git 非常灵活并且您可以以不同的方式使用 push,但它似乎仍然不是您在这里的意思。
将一个本地分支的更改 merge 到另一个本地分支就是 merge
。 (实际上有几种方法可以解决这个问题,但从概念上讲,最直接的方法是 merge ...)
另外,这涉及到一个关于 git 中分支的常见误解——即更改“属于”这个分支或那个分支。在许多源代码控制系统中这可能是正确的,但在 git 中却不是。相反,一个变化要么是,要么不是,从一个分支(或其他引用)“可达”;并且可以(通常)从许多引用文献中获得更改。
(本质上,分支(或其他引用)是指向提交的指针;可以从引用访问该提交。如果该提交有父提交,则可以访问父提交。这通过父指针递归地继续,因此从该 ref 可以访问导致 ref 的整个历史。)
回到图表
x -- O <--(master)
\
A <--(B1)
\
B <--(B2)
您所描述的是 A
和 B
应该 merge 到 master
。因为 A
和 B
正是可以从 B2
到达但不能从 master
到达的提交,这就像简单如
git checkout master
git merge B2
请注意,默认情况下,git 会在此处采取快捷方式,执行“快进”而不是真正的 merge 。这是可以做到的,因为 master
没有无法从 B2
访问的更改。在这种情况下,git 可以更新 master
以将其移动到与 B2
相同的提交。
x -- O -- A <--(B1)
\
B <--(B2)(master)
你可能不希望 git 这样做。 (一些分支/merge 策略要求保留分支拓扑。)在那种情况下你可以说
git checkout master
git merge --no-ff B2
这会给你
x -- O --------------- M <--(master)
\ /
A <--(B1) /
\ /
B --------/
^
(B2)
其中 M
是“merge 提交”。如果有其他更改可从 master
访问但无法从 B2
访问,则 merge 提交会将这些更改与来自 A
和 B 的更改 merge
。
无论哪种方式,B1
仍然指向 A
并且 B2
仍然指向 B
,所以它们都是完全可以从 master
访问。
关于git - 将分支和子分支 merge 回 master,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46667800/
我有这个 html 代码: HELLO WORLD! X V HELLO WORLD! X V 我想按 X(类关闭)将父 div 的高度更改为 20px 并显示 V(类打开),但在每个 d
在会计应用程序的许多不同实现中,有两种主要的数据库设计方法来保存日志和分类帐数据。 只保留 Journal 信息,然后 Ledger 只是 Journal 的一个 View (因为 journal 总
我想在另一个子里面有一个子, sub a { sub b { } } 我想为每次调用 sub b 创建一个新的 sub a 实例。有没有办法在 Perl 中做到这一点? 当我运行上面的
我有一些代码正在查找重复项并突出显示单元格: Private Sub cmdDups_Click() Dim Rng As Range Dim cel As Range Set Rng = ThisW
可能有一个简单的解决方案,但我很难过。 我有一个包含一个 ID 字段的主表。在两个可能的字段中有一个具有该 ID 的子表。想象一个由选手 A 和选手 B 组成的 double 队。Master 表将有
假设我有一个包含对象的数组: [ { "id": "5a97e047f826a0111b754beb", "name": "Hogwarts", "parentId": "
我正在尝试对 MySQL 数据库表执行一对父/子模型的批量插入,但似乎无法使用标准的 ActiveRecord 功能来完成。所以,我尝试了 activerecord-import gem,但它也不支持
我有一个带有多个子类的父抽象类。最终,我希望通过 GUI 中的进度条显示子类中完成的进度。 我目前所做的,我意识到这是行不通的,是在父类中声明为每个子类将覆盖的虚拟方法的事件方法定义。所以像: pub
是否可以通过键数组在对象中设置变量?例如我有这个对象: var obj = {'outer': {'inner': 'value'} }; 并希望设置由键数组选择的值: var keys = ['ou
我有一个名为 companies 的 MySQL 表,如下所示: +---------+-----------+-----------+ | id_comp | comp_name | id_pare
我正在尝试使用 sublime text 在 sublime text 上的 ionic 上打开我的第一个应用程序。它给了我一个“找不到命令”的错误。如何修复? 我试过这些命令: sudo rm -r
不好意思问,但我正在使用 webapp2,我正在设计一个解决方案,以便更容易定义路由 based on this google webapp2 route function .但这完全取决于能够在子级
我有代表树的数字字符串(我不知道是否有官方名称): 012323301212 上面的例子代表了 2 棵树。根用 0 表示。根的直接子代为“1”,“1”的直接子代为“2”,依此类推。我需要将它们分组到由
是否可以在当前 Activity 之上添加 Activity 。例如,假设我单击一个按钮,然后它将第二个 Activity 添加到当前 Activity 。而第二个 Activity 只覆盖了我当前
我很难思考如何为子资源建模。 以作者的书籍为例。你可以有 N 本书,每本书只有一位作者。 /books GET /books POST /books/id PUT /books/id DELETE 到
有人可以向我解释以下内容(python 2.7) 来自已解析文件的两个字符串数字: '410.9''410.9 '(注意尾随空格) A_LIST = ['410.9 '] '410.9' in '41
背景 在 PowerShell 中构建 hash table 是很常见的通过特定属性快速访问对象,例如以 LastName 为基础建立索引: $List = ConvertFrom-Csv @' I
我真的很难弄清楚如何调用嵌套 Polymer Web 组件的函数。 这是标记: rise-distribution组件有 canPlay我想从 rise-playlist
我写了一个小工具转储(以 dot 格式)一个项目的依赖关系图,其中所有位于同一目录中的文件都聚集在一个集群中。当我尝试生成包含相应图形的 pdf 时,dot开始哭: 命令 dot -Tpdf trim
给定一个 CODE ref,是否可以: 访问该 CODE ref 的解析树 通过指定 CODE ref 的解析树来创建一个新的 CODE ref,该解析树可以包含在 1 中返回的解析树的元素 通常我们
我是一名优秀的程序员,十分优秀!