git 本地与远程版本不一致问题解决

再合并代码时报如下错误,(我的操作是把本地代码回滚到某次的提交,此时与远程代码不一致,我改动本地代码,想要提交的时候报如下错误)Your branch and 'origin/feature_zf_tencent2' have diverged, and have 1 and 23 different commits each, respectively.   (use "git pull" to merge the remote branch into yours)

解决方案

git pull --rebase origin ****       (****为分支名)

假设,远程上的 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,还是都要,就会出现上面的提示。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值