git中出现“non-fast-forward”errors时的终极解决方案
来源:互联网 发布:mac os双系统安装教程 编辑:程序博客网 时间:2024/05/22 11:31
如果你是个git新手,通过网上那一页教程学会了使用git bash将自己的项目push到远端repository。那么你一定遇到过如下的问题:
error: failed to push some refs to ‘ur repository’
而如果,你百度了这个问题,你将在百度的前三页搜索中得到完全相同的答案:
问题(Non-fast-forward)的出现原因在于:git仓库中已经有一部分代码,所以它不允许你直接把你的代码覆盖上去。于是你有2个选择方式:
1,强推,即利用强覆盖方式用你本地的代码替代git仓库内的内容
git push -f
2,先把git的东西fetch到你本地然后merge后再push
$ git fetch
$ git merge
以上皆为狗屁
如果你真的照做了:
* 第一个方法会完全覆盖掉你之前的提交。如果你只是提交几个修改,那就真是得不偿失了。
* 第二个方法并没什么卵用。
终极解决方案
出现(non-fast-forward)的根本原因是repository已经存在项目且不是你本人提交(我知道是大概率你提交的,但是git只认地址),你commit的项目和远程repo不一样。这时该怎么办呢?很简单,把远端项目拉回本地:
git pull
然而pull回来之后,你再push依旧会fail。
原因是他们是两个不同的项目,要把两个不同的项目合并,不能简单的git pull。而是
git pull origin master --allow-unrelated-histories
这条命令允许了不同项目的合并。
好了,pull成功了。
接下来
git push origin master
游戏结束。
其实遇到各种坑,都是对原理的不理解导致的。学习git,理解+使用,绝对要比使用+使用事半功倍。共勉。
- git中出现“non-fast-forward”errors时的终极解决方案
- git: non-fast-forward errors
- Git错误non-fast-forward后的解决方案
- git non-fast-forward
- Git,non-fast-forward
- 使用git时遇到的坑 non-fast-forward
- git错误non-fast-forward的解决
- eclipse中git push到远程库中时发生rejected-non-fast-forward错误的解决办法
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Git错误non-fast-forward后的冲突解决
- Eclipse 中 Tomcat启动卡100%(preparing launch delegate...)
- Linux之OOM-killer
- Django 调试时提示: In order to allow non-dict objects to be serialized
- teamViewer与Myeclipse的冲突
- webconfig中配置各种数据库的连接字符串
- git中出现“non-fast-forward”errors时的终极解决方案
- 给你的TextView中的部分文字加入没有下划线的超链接
- 如何动态加载图片
- 在yii的URL中,如何隐藏动态文件夹?
- git-svn使用教程
- Error:Cause: https://downloads.gradle.org/distributions/gradle
- Duplicate entry '0' for key 'PRIMARY'
- android popupwindow 的使用方法()
- js中top.location.href、parent.location.href用法