Git工具 conflict冲突问题解决方案

 更新时间:2020年09月28日 11:58:52   作者:海绵般汲取  
这篇文章主要介绍了Git工具 conflict冲突问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章需要对git具有一定的了解,并且知道如何安装git工具(其实就是上git官网下载个文件,安装)

git这种版本控制工具有什么好处

  第一个,方便可以多人协同开发同一个项目或系统

  第二个,当你系统开发到一个稳定版本后为了开发新的功能,肯定要把开发好后的系统代码进行备份保存起来,不然万一那个不懂事的小程序猿删的代码你咋整呢

而代码仓库可以为你解决这个问题,而使用git仓库的项目,就需要用到git工具

版本控制工具git或svn使用方式来说,一种命令行,一个是使用可视化工具进行操作。

git的可视化工具有很多,大部分原理都想通。(间接调用命令行进行操作。)

简单的clonerepository克隆仓库,openlocal repository打开本地仓库,什么的就不说的

这里以SourceTree界面来举例

一般我们从远程仓库上克隆代码到本地仓库后,我们的操作一般就是,

  1、pull 拉取远程仓库上的代码

  2、修改本地代码,

  3、然后commit,commit时候选择你要提交的你修改过的文件填写提交的作者,日期,说明信息。这样你本地仓库代码已经提交完成了,

  4、将本地仓库和远程仓库进行同步,使用push命令推送到远程仓库

上面的四个步骤是理想化状态下的一般步骤,当单人使用的时候不会出错,两个人可能也不会有问题,但随着人数增多,肯定会遇倒这样那样的问题。

问题情况1:如从远端拉取到正式版本后,我增加的文件,或修改的代码,然后在将修改或增加的代码同步到远端,但在我push之前,有另一个人也从远端拉取得代码

    并且更新完成代码,并push到远程仓库的。这个时候我commit没有问题,但是我push不成功,还有一个就是我也正在修改代码,然后不能将代码pull下来

问题原因:很明显,远程仓库已经被修改的,所以不能推送我们的更改

截图看的更清晰:

我在不同文件夹下拉取的相同的远程仓库一个是在D:/Source_code/MergeRepo 另一个在D:/Source_code/New/MergeRepo

我先将其中一个仓库增加一个文件 “测试push文件时冲突问题.txt”

常规操作,commit push,完成

我们可以看到文件已经上传到远程分支上的

再接着看另一个本地仓库,可以看到下图,pull按钮有一个提示,远程仓库已经更新的,但这个时候我们可能还在开发新的功能,

可能这个工具没有显示远程有更新可以拉取,我们想要将写好的功能提交到远程仓库

执行,commit ,push,然后就,,出现错误,远程仓库已经更新的,不能推送。

这需要先将远程代码pull下来,但是可能也拉取不成功

因为新功能会存在修改我们拉取下来的项目的文件,所以我们当前就不能将远程更新的代码拉取下来,会提示我们先stashsave我们修改过的代码,

然后再pull更新远程代码,最后再将我们存放到栈里面的开发新功能代码修改弹出栈,stashpop

  解决办法:所以我们要先把远程仓库的代码拉取下来,但是会存在拉取不下来的问题。

      我们需要将我们的更改存放到栈内存中,也就是使用stash save命令,然后在拉取服务器端更新过的代码,然后在使用stashpop命令将我们之前的修改取出来合并到

      本地代码仓库中去。

      当然上面的stash pop弹出改变的内容时会有conflict问题出现,我们找到发生冲突的文件,讲我们需要的文件内容保留下来就可以啦

      (以后有截图的时候再详细讲)

      最后冲突解决完成的,我们再按照常规流程走,commit,push

情况2:需要在正式发布好的产品上添加新的功能,不可能在主分支上开发新功能,比如我们正式版本是在master分支上,

    

  解决方法:我们就需要在复制一份本地仓库中的master版本,取新的

      名字,在这个新的名字分支上开发新的功能,然后我们将新的版本提交到我们远程仓库分支上上。

      提交完成后,我们将本地仓库切换到master分支,在选中我们开发的新功能分支,右键点击merge合并选中的分支到当前分支中。

      到这里,新功能开发任务就完成啦,合并到master分支,主分支也拥有这个新开发的功能模块的

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 深入了解MyBatis参数

    深入了解MyBatis参数

    今天小编就为大家分享一篇关于深入了解MyBatis参数,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • java实现音频文件播放功能

    java实现音频文件播放功能

    这篇文章主要为大家详细介绍了java实现音频文件播放功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • Java parseInt解释加方法示例

    Java parseInt解释加方法示例

    使用此方法得到的原始数据类型的一个特定的字符串。 parseXxx()是一个静态方法,可以有一个参数或两个
    2013-11-11
  • MyBatis SELECT基本查询实现方法详解

    MyBatis SELECT基本查询实现方法详解

    这篇文章主要介绍了MyBatis SELECT基本查询实现方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • Java中创建线程的四种方法解析

    Java中创建线程的四种方法解析

    这篇文章主要介绍了Java中创建线程的四种方法解析,线程是Java编程语言中的一个重要概念,它允许程序在同一时间执行多个任务,线程是程序中的执行路径,可以同时执行多个线程,每个线程都有自己的执行流程,需要的朋友可以参考下
    2023-10-10
  • ResponseBodyAdvice踩坑及解决

    ResponseBodyAdvice踩坑及解决

    这篇文章主要介绍了ResponseBodyAdvice踩坑及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Spring Security整合CAS的示例代码

    Spring Security整合CAS的示例代码

    本篇文章主要介绍了Spring Security整合CAS的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • Java高级应用之斗地主游戏

    Java高级应用之斗地主游戏

    这篇文章主要为大家详细介绍了Java高级应用之斗地主游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • MyBatis-Plus不使用数据库默认值的问题及解决

    MyBatis-Plus不使用数据库默认值的问题及解决

    这篇文章主要介绍了MyBatis-Plus不使用数据库默认值的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • java web学习_浅谈request对象中get和post的差异

    java web学习_浅谈request对象中get和post的差异

    下面小编就为大家带来一篇java web学习_浅谈request对象中get和post的差异。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05

最新评论