git pull时冲突的几种解决方式(小结)

 更新时间:2020年07月24日 11:28:23   作者:雪山上的蒲公英  
这篇文章主要介绍了git pull时冲突的几种解决方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

仅结合本人使用场景,方法可能不是最优的

1. 忽略本地修改,强制拉取远程到本地

主要是项目中的文档目录,看的时候可能多了些标注,现在远程文档更新,本地的版本已无用,可以强拉

git fetch --all
git reset --hard origin/dev
git pull

关于commit和pull的先后顺序,commit——》pull——》push 和 pull——》commit——》push的顺序,两种情况都遇到过代码冲突。解决方法如下:

2. 未commit先pull,视本地修改量选择revert或stash

// 场景
同事 有新提交
我 没有pull -> 修改了文件 -> pull -> 提示有冲突

2.1 本地修改量小

如果本地修改量小,例如只修改了一行,可以按照以下流程

-> revert(把自己的代码取消) -> 重新pull -> 在最新代码上修改 -> [pull确认最新] -> commit&push

2.2 本地修改量大,冲突较多

有两种方式处理

-> stash save(把自己的代码隐藏存起来) -> 重新pull -> stash pop(把存起来的隐藏的代码取回来 ) -> 代码文件会显示冲突 -> 右键选择edit conficts,解决后点击编辑页面的 mark as resolved-> commit&push

-> stash save(把自己的代码隐藏存起来) -> 重新pull -> stash pop(把存起来的隐藏的代码取回来 ) -> 代码文件会显示冲突 -> 右键选择resolve conflict -> 打开文件解决冲突 ->commit&push

另外,由于我是通过IDEA来操作git的,所以显示冲突时,我是在图形化界面操作的示意如下

3. 已commit未push,视本地修改量选择reset或直接merge

// 场景
同事 有新提交
我 没有pull -> 修改了文件 -> commit -> pull -> 提示有冲突

3.1 修改量小,直接回退到未提交的版本(可选择是否保存本地修改)

如果本地修改量小,例如只修改了一行,可以按照以下流程

-> reset(回退到未修改之前,选hard模式,把自己的更改取消) -> 重新pull -> 在最新代码上修改 -> [pull确认最新] -> commit&push

ps:实际上完全可以采取直接merge的方法,这里主要是根据尽量避免merge的原则,提供一种思路

3.2 修改量大,直接merge,再提交(目前常用)

-> commit后pull显示冲突 -> 手动merge解决冲突 -> 重新commit -> push

到此这篇关于git pull时冲突的几种解决方式(小结)的文章就介绍到这了,更多相关git pull冲突内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 死锁问题详解

    死锁问题详解

    本文详细介绍了死锁,例如死锁的概念、产生死锁的条件、如何预防死锁等等,有需要的朋友可以自行参考本篇文章,希望对你有所帮助
    2021-08-08
  • Mac下更换Homebrew镜像源的实现方法

    Mac下更换Homebrew镜像源的实现方法

    本文主要介绍了Mac下更换Homebrew镜像源的实现方法,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2021-07-07
  • ArcGIS Pro 按照字段进行融合或拆分的操作步骤

    ArcGIS Pro 按照字段进行融合或拆分的操作步骤

    ArcGIS Pro 是 Esri 提供的功能全面的专业桌面 GIS 应用程序,这篇文章主要介绍了ArcGIS Pro 按照字段进行融合或拆分,需要的朋友可以参考下
    2024-02-02
  • qqwry.dat的数据结构图文解释

    qqwry.dat的数据结构图文解释

    QQwry.dat可以看作是一种数据文件,通过它能完成以下任务
    2009-02-02
  • Hadoop介绍与安装配置方法

    Hadoop介绍与安装配置方法

    这篇文章主要介绍了Hadoop介绍与安装配置教程,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • Dreamweaver中如何设定文字大小、字体、颜色

    Dreamweaver中如何设定文字大小、字体、颜色

    这篇文章主要给大家介绍了关于Dreamweaver中如何设定文字大小、字体、颜色的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2007-06-06
  • Elasticsearch在应用中常见错误示例解析

    Elasticsearch在应用中常见错误示例解析

    这篇文章主要为大家介绍了Elasticsearch在应用中常见错误示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • 带你了解HDFS的Namenode 高可用机制

    带你了解HDFS的Namenode 高可用机制

    为了Hadoop更好的应用,Hadoop 2.0 及之后版本增加了 Namenode 高可用机制,本文详细介绍 Namenode 高可用机制,可供大家参考
    2021-08-08
  • 分享下GET和POST的真正区别

    分享下GET和POST的真正区别

    如果有人问你,GET和POST,有什么区别?你会如何回答
    2013-02-02
  • jetbrains mono字体安装方法(推荐)

    jetbrains mono字体安装方法(推荐)

    JetBrains 推出了一款名为 "Mono" 的字体。按照官方的说法,Mono 是专为开发者打造的编程字体。这篇文章主要介绍了jetbrains mono字体安装方法,需要的朋友可以参考下
    2020-01-01

最新评论