执行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
假设,远程上的 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 电脑上:
这个命令等同于:
执行之后,B 电脑上的历史线就会变成
A -> B -> C -> D -> E
,然后你就可以push
了多说一句,之所以显示上面的“错误”,是因为
A -> B -> C -> D
和A -> B -> E
有一个共同的祖先B
,你在本地多了一个 commitE
,远程多了两个 commitsC
和D
。这个时候如果你要在A -> B -> E
的 branch 上push
,git 猜不出到底想保留C
和D
,还是只要E
,还是都要,就会出现上面的提示。