git pull提示有冲突时拉取代码(有<<<<<<< Updated upstream和=======和>>>>>>> Stashed changes冲突标记符的代码)

一、前言

多人协作开发时经常会在git pull XXX时控制台提示:

error: Your local changes to the following files would be overwritten by merge:
Please commit your changes or stash them before you merge.

的拉取报错。很明确,这是在告诉你,你当前修改的代码和要拉取分支的带有代码冲突,git并不知道该怎么处理这些冲突,所以给你报告出来了。那么,怎么解决这个问题?

二、问题分析、解决

产生这个报错的原因就是因为你和别人修改了相同的代码文件,比如在Vue中可能就是几个人修改了同一(几)个组件中的代码。

解决方式(2种)

1、先不拉取代码,经过协商,在git pull之前选择保留你的代码还是保留别人的代码,然后逐行在没有明确冲突标记的代码中进行手动删除,直到这个(些)代码文件没有冲突。或者决定你的修改都不保留(会放弃你未提交的所有修改,慎用),直接执行:

// 强制回退你本次所有的代码修改到你上次的提交
git reset --hard
// 拉别人的代码
git pull XXX

2、先把代码都拉下来,然后在有明确的冲突标记(<<<<<<< Updated upstream和=======和>>>>>>> Stashed changes是冲突标记符)的代码中进行修改。

// 这会将你现在的代码临时保存起来
1、git stash
// 拉取别人的代码
2、git pull XXX
// 这个命令会将刚才临时存储的你的代码融合进来
3、git stash pop

我用的代码编辑器是VS Code,真实样子是这样:
在这里插入图片描述
其中<<<<<<< Updated upstream到=======之间的代码是你拉取的别人的代码,=======到>>>>>>> Stashed changes是你自己本次修改的代码。这样有了明确的冲突标记符再修改起来就很方便了。

三、说明

解决办法2的这个操作会有冲突标记的前提是几个人修改了同一行代码,如果只是修改了同一个文件下的不同行,执行上述操作后会将代码进行融合,即你修改的代码和别人修改的代码都在,由于不在同一行,所以不会有冲突标记包裹。

  • 13
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值