为了账号安全,请及时绑定邮箱和手机立即绑定

git Your branch and 'origin/dev' have diverged

git Your branch and 'origin/dev' have diverged

Git
慕勒3428872 2018-07-23 21:06:02
执行git push时出现了以下错误:Your branch and 'origin/dev' have diverged,and have 1 and 2 different commits each, respectively.我在两台电脑上工作,电脑A和B初始都是up-to-date,之后我先在A中commit并push了几次,然后我现在在电脑B中从初始状态编写,然后试图在commit之后push,出现了上述问题(使用同一个本地和云分支)。现在我想:合并这二者,显示不同,然后重新commit并push
查看完整描述

1 回答

?
POPMUISE

TA贡献1765条经验 获得超5个赞

假设,远程上的 commit 是 A -> B
你在 A 电脑上 commit 和 push 之后,远程变成了 A -> B -> C -> D
现在,B 电脑上还是 A -> B。然后你 commit 了,那么 B 电脑上就是 A -> B -> E

所以,你需要的是把 B 电脑上的历史线变成 A -> B -> C -> D -> E
这时,你需要在 B 电脑上:

git pull --rebase origin dev

这个命令等同于:

git fetch origingit rebase origin/dev

执行之后,B 电脑上的历史线就会变成 A -> B -> C -> D -> E,然后你就可以 push 了


多说一句,之所以显示上面的“错误”,是因为 A -> B -> C -> D 和 A -> B -> E 有一个共同的祖先 B,你在本地多了一个 commit E,远程多了两个 commits C 和 D。这个时候如果你要在 A -> B -> E 的 branch 上 push,git 猜不出到底想保留 C 和 D,还是只要 E,还是都要,就会出现上面的提示。


查看完整回答
反对 回复 2018-07-29
  • 1 回答
  • 0 关注
  • 1899 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信