多人协同开发那些事 先看懂再操作(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

相关文章

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

基于C#实现PDF文件合并工具

《基于C#实现PDF文件合并工具》这篇文章主要为大家详细介绍了如何基于C#实现一个简单的PDF文件合并工具,文中的示例代码简洁易懂,有需要的小伙伴可以跟随小编一起学习一下... 界面主要用于发票PDF文件的合并。经常出差要报销的很有用。代码using System;using System.Col