问题(Non-fast-forward)的出现原因在于:git仓库中已经有一部分代码,所以它不允许你直接把你的代码覆盖上去。于是你有2个选择方式:
git push –f
如果你用的是Egit则可以在推送界面选择“Force Update All Specs”即可,如下图:
$ git fetch
$ git merge
这2句命令等价于
git pull
如下图:
l
解决方法:
1.在本地工程目录找到config文件打开编辑,如果你用的是Egit则可以通过:windows》preferences》team》git》configuration》repository Settings》open配置文件即可。
如下图:
2.在config文件中添加:
[branch "master"]
remote = origin
merge = refs/heads/master
以上的master要改为你要提交的分支。
3.再执行pull方法即可。
如果没对分支的配置文件中添加推送配置的话,则无法向服务器推送这个分支的。如下图:
解决这个问题需要在.get/config的文件中添加如下配置即可:
[remote"origin"]
push=refs/heads/dev:refs/heads/dev
这句话的意思是将本地的dev分支推送到服务器的dev分支,或者也可以通过可视化界面来操作,如下图:
在上图中的Sourceref:中选择本地要推送的分支,在Destinationref:中选择要推送到服务器上的分支,如果你想将此次的配置保存下来的话可以选择Save specifications in ‘origin’ configuration 复选框即可(选择此复选框会在config文件中自动添加push =refs/heads/dev:refs/heads/dev)。
推荐阅读:
原文地址:http://blog.csdn.net/fengyuzhengfan/article/details/44245175