git push 出错的两种情况

今天改完代码调用git push的时候发生如下错误

Pushing to git@github.com:cuijianaaa/test.git
To git@github.com:cuijianaaa/test.git
 ! [rejected]        master -> master (non-fast-forward)
error: failed to push some refs to 'git@github.com:cuijianaaa/test.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Merge the remote changes (e.g. 'git pull')
hint: before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

翻译成中文意思是:由于你当前分支的末端落后与远程端对应分支,所以无法更新,请在提交之前把远端对应分支的改变合并过来再push。

可能的原因:
1、是本地做了版本的回退,比如用了git reset,所以本地分支版本落后于远程端对应分支。
2、在你push之前别人有push同一个分支的代码,导致远程比本地新。

对于1:
这种情况如果确保本地强制回退是舍掉了一些没用的东西,则可以用

git push -f

注意:
强制push本地分支将远程对应分支覆盖。这样操作一定要小心,因为push -f之后远程对应分支之前比本地的多的一些提交将丢失。如果不确保本地回退对应部分可以舍弃,则要用情况2的方法解决

对于2:

git fetch #把远程最新的更新到本地 
git merge #把远程最新的合并到本地分支

or

git pull #git pull = git fetch + git merge
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值