当前位置:   article > 正文

git中出现“non-fast-forward”errors时的终极解决方案_denying non-fast-forward

denying non-fast-forward

如果你是个git新手,通过网上那一页教程学会了使用git bash将自己的项目push到远端repository。那么你一定遇到过如下的问题:
在这里插入图片描述

error: failed to push some refs to ‘ur repository’
  • 1

而如果,你百度了这个问题,你将在百度的前三页搜索中得到完全相同的答案:

问题(Non-fast-forward)的出现原因在于:git仓库中已经有一部分代码,所以它不允许你直接把你的代码覆盖上去。于是你有2个选择方式: 
1.强推,即利用强覆盖方式用你本地的代码替代git仓库内的内容 
git push -f 
2. 先把git的东西fetch到你本地然后merge后再push 


     $ git fetch 
     $ git merge
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

以上皆为狗屁
如果你真的照做了:

  • 第一个方法会完全覆盖掉你之前的提交。如果你只是提交几个修改,那就真是得不偿失了。
  • 第二个方法并没什么卵用。

终极解决方案
出现(non-fast-forward)的根本原因是repository已经存在项目且不是你本人提交(我知道是大概率你提交的,但是git只认地址),你commit的项目和远程repo不一样。这时该怎么办呢?很简单,把远端项目拉回本地:

git pull
  • 1

然而pull回来之后,你再push依旧会fail。
原因是他们是两个不同的项目,要把两个不同的项目合并,不能简单的git pull。而是

git pull origin master --allow-unrelated-histories
  • 1

这条命令允许了不同项目的合并。
好了,pull成功了。
接下来

git push origin master
  • 1

游戏结束。

原文链接:https://blog.csdn.net/kiddd_fu/article/details/78247290

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/533065
推荐阅读
相关标签
  

闽ICP备14008679号