多人协同开发那些事 先看懂再操作(Git分支合并冲突的解决)

2023-10-19 20:20

本文主要是介绍多人协同开发那些事 先看懂再操作(Git分支合并冲突的解决),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Git多人协同开发那些事(分支合并冲突的解决)

当开发一个大型项目时通常都是许多人进行合作,每个人负责项目的一部分,Git是实现多人协同开发最常见的工具,但是对于刚接触Git的人来说,多人协同开发会遇见很多问题,这篇博客的内容主要就是为了给出多人协同开发的正确步骤,并对这个过程中遇到的问题进行解释和解决。

一、协同开发的准备工作 🍉

1、新建一个仓库(当然

2、创建主分支,即上传项目的初始内容到master分支

3、团队内成员进行分工(各个成员之间负责的内容用尽量不冲突

二、开发阶段 🍇

1、每个成员将远程仓库主(master)分支的内容clone下来

2、按照分工进行自己负责的工作

三、提交阶段 🍍

这个阶段是问题发生最严重的的阶段,下面的步骤都是按照有管理员的情况下阐述的。管理员的作用。

1️⃣每个成员在完成自己的工作后,首先要注意远程仓库的变化
(1) 为什么要注意远程仓库的变化?

一开始团队内每个成员都是基于最开始的master分支进行工作的,随着时间的流逝,会有成员上传自己的内容,如果成员甲push了自己的内容到master分支后,那么master分支中的内容就会被甲所提交的内容所覆盖,这时如果有个成员乙不注意远程仓库的变化,也直接将自己的内容push到远程的master分支上,那么远程仓库的主分支就会被成员乙策内容所替换,也就是成员甲所push的内容会被成员乙提交的内容覆盖掉

(2) 该如何注意远程仓库的变化?

方式一:拉取远程分支(最常用

即使用pull指令,该指令可以理解为两个步骤:

  • 获取远程分支
  • 将获取的远程分支与本地分支合并

拉取后,由于自动合并,就会将远端的内容合并到本地分支,此时再push上去,本地内容将远端分支覆盖后就保留了成员甲的内容。但是合并过程中可能会出现一些错误。

方式二:获取远程分支(最安全)

即使用fetch指令,该指令就是获取远端指定分支的最新版到本地(即在本地创建一个新分支内容为远端指定分支的最新版)。获取分支后就可以比较、查看远程分支的内容,随后若想push,可选择与获取的分支进行merge(合并)再push。

2️⃣获取远程仓库的最新版,与本地进行合并

合并时会产生的问题:合并冲突

会产生的情况:

  • 两个人对同一项目的不同文件进行了修改☑️
  • 两个人对同一项目的同一文件的不同区域进行了修改☑️
  • 对同一项目的同一文件的同一区域进行了不同修改❌

上述三种情况的前两种都可以由Git进行自动合并,而第三种情况无法进行自动合并,需要**手动合并**。

问题1:什么是自动合并?

合并本质上可以理解为将两个人(分支)对项目的基础的修改整合到一块,注意是对项目的修改。上述三种情况的前两种是两个人对项目的不同区域进行修改,互不干扰,所以Git可以自动的将两个人对项目的修改整合到一起,如下面的演示图。

演示图

问题2:为什么需要手动合并?

当可以自动合并时,说明两个人的修改不会冲突,但是当两个人对同一文件的同一区域进行了修改那么这两个修改就会产生冲突,Git将无法整合这两个修改,因为Git不知道它该保留两个修改中的哪一个(或是要一并保存),这是就需要人工进行手动合并了。

问题三:什么是手动合并?

当Git不知道该保留两个修改中的哪一个时,就需要人来进行这个决策,可以选择保留两个修改中的任意一个,或是选择将两个修改全部保留。完成上述决策就是手动合并的目的。

3️⃣合并过后,就可以上传(push)到远程仓库自己的分支了

四、审核阶段 🍒

管理员审核代码,没有发现问题后就可以将其与主分支进行merge,管理员应尽快完成这个过程,从而确保成员拉取到的都是最新版本。

管理员合并过程中可能也会发生冲突,需要管理员联系成员了解情况后进行手动合并。

管理员的作用:

维护远程仓库的master分支,包括以下:

  • 检查各个成员分支的代码有无问题
  • 将成员分支的代码合并到master分支
  • 合并发生冲突时,进行手动合并

如果大家发现文章有什么地方存在问题,希望可以指出,十分感谢。

这篇关于多人协同开发那些事 先看懂再操作(Git分支合并冲突的解决)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/242138

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的