我有四个分支(master, b1, b2和b3)。我在b1-b3上工作后,我意识到我在分支主上有一些应该在所有其他分支中更改的东西。我改变了我在master中需要的东西…这是我的问题:
我如何用主分支代码更新所有其他分支?
我有四个分支(master, b1, b2和b3)。我在b1-b3上工作后,我意识到我在分支主上有一些应该在所有其他分支中更改的东西。我改变了我在master中需要的东西…这是我的问题:
我如何用主分支代码更新所有其他分支?
当前回答
对于这个问题有两种选择。
1) Git 变基
2)去合并
只有与上述两者不同的合并情况下,将有额外的历史提交
1) git结帐分支(b1,b2,b3)
2) git rebase origin/master(如果冲突可以通过git rebase -continue在本地解决)
3)去推
或者,git合并选项是类似的方式
1) git checkout“your_branch”(b1,b2,b3)
2)转到合并母版
3)去推
其他回答
Git checkout master git拉 Git签出feature_branch Git重基master Git push -f
你需要做一个强有力的推动后,对主调基
@cmaster给出了最好的详细回答。简而言之:
git checkout master #
git pull # update local master from remote master
git checkout <your_branch>
git merge master # solve merge conflicts if you have`
您不应该重写分支历史记录,而应该保持它们的实际状态以供将来引用。当合并到master时,它会创建一个额外的提交,但这很便宜。提交不需要成本。
如果你想要恢复到上一次提交并删除日志历史记录
使用下面的命令,让我们假设你想要去到以前的提交,它有commititid SHA - 71e2e57458bde883a37b332035f784c6653ec509,你可以指向这个提交,它将不会显示任何日志消息在这个提交之后,所有的历史将被擦除。
git push origin +71e2e57458bde883a37b332035f784c6653ec509^:master
您可以合并,也可以使用git的选择性跨分支应用单独的提交。
从master更新你的分支:
git checkout master
git pull
git checkout your_branch
git merge master