【Git多人协作开发】不同的分支下的多人协作开发模式
目录
0.前言背景
1.开发者1☞完成准备工作&协作开发
1.1查看分支情况
1.2创建本地分支feature-1
1.3三板斧
1.4push推本地分支feature-1到远程仓库
2.开发者2☞完成准备工作&协作开发
2.1创建本地分支feature-2
2.2三板斧
2.2push推送本地feature-2到远程仓库
3.出现同一分支下多人协作开发问题
3.1查看分支情况
3.2拉取远程feature-2分支
3.3创建本地feature-2分支并且和远程建立联系
3.4三板斧
3.5回到不同分支多人协作开发问题
4.将内容合并进master分支
4.1无冲突演示feature2
4.2存在冲突演示feature1
4.2.1拉取pull最新master版本
4.2.2feature合并master
4.2.3push推送至远程仓库
4.2.4远程仓库提交PR:master合并feature1
5.删除无用分支feature-1或者feature-2
6.总结模式
0.前言背景
不同分支去实现不同的function
可以是不同开发者实现不同的function使用不同的分支。
可以是不同开发者实现不同的function使用不同的分支。
可以是同一份文件,也可以是不同文件。
❗重点是:不同分支针对是不同的function
- 目标:远程master分支下新增function1和function2文件。
- 实现:由开发者1新增function1,由开发者2新增function2。
- 条件:在不同分支下协作完成,各自让某一个功能私有某一个分支。
- 重点:在公司里面,都是一个功能function 对应一个分支这样子来玩的。push不会出现冲突问题。
- 同一分支下多人协作开发场景:push会出现冲突问题。
1.开发者1☞完成准备工作&协作开发
1.1查看分支情况
git branch -a
查看分支情况(远程分支/本地分支,远程分支是远程分支,本地分支是本地分支)
1.2创建本地分支feature-1
- 无论是本地创建还是远程创建,都需要基于master的最新一次提交的版本。
- 在本地创建的feature的时候必须确保基于本地master分支创建的feature-1分支中的master分支相较于远程分支master分支是最新一次提交记录的版本。
- 好习惯:git checkout master git pull
- git checkout -b feature-1:创建本地分支feature-1
1.3三板斧
vim function1
git add function1
git commit -m "add func1"
git push origin feature-1
1.4push推本地分支feature-1到远程仓库
git push origin feature-1
注意:在推送本地分支到远程仓库时(远程仓库创建分支的同时),与本地仓库建立联系了
2.开发者2☞完成准备工作&协作开发
2.1创建本地分支feature-2
- 无论是本地创建还是远程创建,都需要基于master的最新一次提交的版本。
- 在本地创建的feature的时候必须确保基于本地master分支创建的feature-1分支中的master分支相较于远程分支master分支是最新一次提交记录的版本。
- 好习惯:git checkout master git pull
- git checkout -b feature-2:创建本地分支feature-2
【Windows下不用命令直接操作也可】
2.2三板斧
git add function2
git commit -m "add func2"
git push origin feature-2
2.2push推送本地feature-2到远程仓库
git push origin feature-2
- 注意:在推送本地分支到远程仓库时(远程仓库创建分支的同时),与本地仓库建立联系了
- 发现不同开发者正在协作开发的过程中,并没有解决冲突。是同一份文件的功能开发push推送也不会有冲突
- 因为是在不同的分支下开发,各自私有的分支,所以不会有冲突。
3.出现同一分支下多人协作开发问题
正常情况下,你俩就可以在⾃⼰的分⽀上进⾏专业的开发了!
但天有不测⻛云,你的⼩伙伴突然⽣病了,但需求还没开发完,需要你帮他继续开发,于是他便把feature-2 分⽀名告诉你了。这时你就需要在⾃⼰的机器上切换到 feature-2 分⽀帮忙继续开发,要做的操作如下:
- pull拉取远程仓库的feature-2分支到开发者1本地服务器上
- 建立联系
- 开发然后push推送
3.1查看分支情况
git branch -a
查看分支情况(远程分支/本地分支,远程分支是远程分支,本地分支是本地分支)
3.2拉取远程feature-2分支
git pull :这里短pull是拉取远程仓库的内容。(而非分支下的内容)
3.3创建本地feature-2分支并且和远程建立联系
git checkout -b dev origin/dev:在创建dev分支的时,切换到了本地dev分支下,同时将本地dev分支和远程的dev分支建立了一个连接。
3.4三板斧
vim function2
git add function2
git commit -m "add func2"
git push origin feature-2
3.5回到不同分支多人协作开发问题
此刻开发者1开发完function-2的1/3内容了,他的亲亲同事病好了。他准备在他的电脑上继续开发。此刻同事电脑上,并没有开发者1开发的内容。所以他需要先拉取pull远程仓库的内容,再继续开发。
- 建立远程feature-2分支和本地feature-2分支的联系
- 拉取远程仓库feature-2的内容
- 继续开发☞完成开发
- push推送至远程仓库(已经建立本地和远程的联系☞直接短命令push直接即可)(这里的短命令push就是推送分支底下的内容)
4.将内容合并进master分支
- function1和function2二者功能都完成了开发操作,现在需要都merge都master分支上去
- 解决方案:提交PR申请单
- 开发人员:PR☞申请单☞审查员:审核(老板、项目经理、技术经理)☞merge
- 存在两种情况
【1】开发分支feature直接和主分支master最新一次提交版本merge合并。(没有合并冲突)----演示feature-2
开发分支feature直接和主分支master最新一次提交版本merge合并存存冲突。--------演示feature-1
开发分支feature直接和主分支master最新一次提交版本merge合并存存冲突。
- 若master合并feature,存在冲突,则在master上去解决的。(可能出现更大bug问题
- 若feature合并master分支,存在冲突,在feature上解决的。再让master合并feature
- 注意:本地merge合并一定要pull拉取远程仓库最新的一次提交的版本的master分支
【2】本地☞远程
- 本地服务器操作:在本地仓库切换至feature-1 mereg合并 本地master分支,存在冲突,手动解决冲突,三板斧提交并且推送push。
- 远程服务器操作:在远程仓库master主分支 merge合并feature-1分支
【3】或者全在本地——前面博文演示过
- 在本地仓库切换至feature-1 mereg合并 本地master分支,存在冲突,手动解决冲突,三板斧提交
- 切换至本地master分支合并
- 最后push推送至远程仓库
4.1无冲突演示feature2
4.2存在冲突演示feature1
4.2.1拉取pull最新master版本
git checkout master
git pull:这里的短命令push就是推送分支底下的内容
4.2.2feature合并master
git checkout feature-1
git merge master
下面页面表示merge的两个分支,没有任何的冲突。Ctrl+x自动退出了
4.2.3push推送至远程仓库
git push origin feature-1
注意:在推送本地分支到远程仓库时(远程仓库创建分支的同时),与本地仓库建立联系了
4.2.4远程仓库提交PR:master合并feature1
5.删除无用分支feature-1或者feature-2
6.总结模式
总结:
- 每个开发者都私有一个分支去开发各自的功能。(同一文件/不同文件)
- 开发完成之后(三板斧)push,基本不会出现冲突。
- 会出现小插曲(同事生病等)。
- 完成之后需要将开发分支部分合并到master。三个方案☞建议选择:远程和本地混合。
相关文章:

【Git多人协作开发】不同的分支下的多人协作开发模式
目录 0.前言背景 1.开发者1☞完成准备工作&协作开发 1.1查看分支情况 1.2创建本地分支feature-1 1.3三板斧 1.4push推本地分支feature-1到远程仓库 2.开发者2☞完成准备工作&协作开发 2.1创建本地分支feature-2 2.2三板斧 2.2push推送本地feature-2到远程仓库…...
Lua 复数计算器
Lua复数计算器 主要包括复数的加减乘除操作,以及打印 编写复数类 -- ***** 元类 ***** Complex {real 0, imag 0}-- 构造函数 function Complex:new(real, imag)local o o or {}o.real real or 0o.imag imag or 0setmetatable(o, self)self.__index selfr…...
深入MySQL中的IF和IFNULL函数
在数据库查询中,我们经常需要根据条件来决定数据的显示方式。MySQL提供了多种内置函数来帮助我们实现这种条件逻辑,其中IF和IFNULL是两个非常有用的函数。在这篇博客中,我们将深入探讨这两个函数的用法和它们在实际查询中的应用。 IF函数 I…...

AI多模态实战教程:面壁智能MiniCPM-V多模态大模型问答交互、llama.cpp模型量化和推理
一、项目简介 MiniCPM-V 系列是专为视觉-语⾔理解设计的多模态⼤型语⾔模型(MLLMs),提供⾼质量的⽂本输出,已发布4个版本。 1.1 主要模型及特性 (1)MiniCPM-Llama3-V 2.5: 参数规模: 8B性能…...

Docker 搭建Elasticsearch详细步骤
本章教程使用Docker搭建Elasticsearch环境。 一、拉取镜像 docker pull docker.elastic.co/elasticsearch/elasticsearch:8.8.2二、运行容器 docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-n...
mysql中提供的函数
文章目录 1.聚合函数2.字符串函数3.数值函数4.日期函数5.流程函数 MySQL 是一个功能强大的关系型数据库管理系统,其中包含了丰富的内置函数,用于处理各种数据操作和查询。这些函数可以分为多种类型,包括字符串函数、数值函数、日期和时间函数…...

加速下载,揭秘Internet Download Manager2024下载器的威力!
1. Internet Download Manager(IDM)是一款广受欢迎的下载管理软件,以其强大的下载加速功能和用户友好的界面著称。 IDM马丁正版下载如下: https://wm.makeding.com/iclk/?zoneid34275 idm最新绿色版一键安装包链接:抓紧保存以…...
oracle 宽表设计
Oracle宽表设计主要涉及到数据库表或视图中字段(列)数量较多的情况。在Oracle 23c及以后的版本中,数据库表或视图中允许的最大列数已增加到4096,这为宽表设计提供了更大的灵活性。以下是对Oracle宽表设计的详细分析: …...

winrar安装好后,鼠标右键没有弹出解压的选项
本来安装挺好的,可以正常使用,有天我把winrar相关的文件挪了个位置,就不能正常使用了。 然后我去应用里面找,找到应用标识了,但是找不到对应的文件夹(因为我挪到另外一个文件夹里了)。 于是我找…...

数字图像处理笔记(一)---- 图像数字化与显示
系列文章目录 数字图像处理学习笔记(一)---- 图像数字化与显示 数字图像处理笔记(二)---- 像素加图像统计特征 数字图像处理笔记(三) ---- 傅里叶变换的基本原理 文章目录 系列文章目录前言一、数字图像处理二、图像数…...

Unity UGUI 之 事件接口
本文仅作学习笔记与交流,不作任何商业用途 本文包括但不限于unity官方手册,唐老狮,麦扣教程知识,引用会标记,如有不足还请斧正 本文在发布时间选用unity 2022.3.8稳定版本,请注意分别 1.什么是事件接口&…...

Hadoop、HDFS、MapReduce 大数据解决方案
本心、输入输出、结果 文章目录 Hadoop、HDFS、MapReduce 大数据解决方案前言HadoopHadoop 主要组件的Web UI端口和一些基本信息MapReduceMapReduce的核心思想MapReduce的工作流程MapReduce的优缺点Hadoop、HDFS、MapReduce 大数据解决方案 编辑 | 简简单单 Online zuozuo 地址…...
Dubbo SPI 之负载均衡
1. 背景介绍 在分布式系统中,负载均衡是一项核心技术,旨在将请求合理地分配到多个服务实例上,以提高系统的性能和可靠性。Dubbo 作为一个高性能的 Java RPC 框架,提供了多种负载均衡策略来满足不同的业务需求。本文将深入探讨 Du…...

规范:前后端接口规范
1、前言 随着互联网的高速发展,前端页面的展示、交互体验越来越灵活、炫丽,响应体验也要求越来越高,后端服务的高并发、高可用、高性能、高扩展等特性的要求也愈加苛刻,从而导致前后端研发各自专注于自己擅长的领域深耕细作。 然…...
Python --NumPy库基础方法(2)
NumPy Numpy(Numerical Python) 是科学计算基础库,提供大量科学计算相关功能,比如数据统计,随机数生成等。其提供最核心类型为多维数组类型(ndarray),支持大量的维度数组与矩阵运算,Numpy支持向…...
音视频入门基础:H.264专题(15)——FFmpeg源码中通过SPS属性获取视频帧率的实现
音视频入门基础:H.264专题系列文章: 音视频入门基础:H.264专题(1)——H.264官方文档下载 音视频入门基础:H.264专题(2)——使用FFmpeg命令生成H.264裸流文件 音视频入门基础&…...

【C++高阶】哈希之美:探索位图与布隆过滤器的应用之旅
📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C “ 登神长阶 ” 🤡往期回顾🤡:模拟实现unordered 的奥秘 🌹🌹期待您的关注 🌹🌹 ❀哈希应用 Ǵ…...

文件包涵条件竞争(ctfshow82)
Web82 利用 session.upload_progress 包含文件漏洞 <!DOCTYPE html> <html> <body> <form action"https://09558c1b-9569-4abd-bf78-86c4a6cb6608.challenge.ctf.show//" method"POST" enctype"multipart/form-data"> …...

通信原理-思科实验三:无线局域网实验
实验三 无线局域网实验 一:无线局域网基础服务集 实验步骤: 进入物理工作区,导航选择 城市家园; 选择设备 AP0,并分别选择Laptop0、Laptop1放在APO范围外区域 修改笔记本的网卡,从以太网卡切换到无线网卡WPC300N 切…...
*算法训练(leetcode)第三十一天 | 1049. 最后一块石头的重量 II、494. 目标和、474. 一和零
刷题记录 *1049. 最后一块石头的重量 II*494. 目标和474. 一和零 *1049. 最后一块石头的重量 II leetcode题目地址 本题与分割等和子集类似,要达到碰撞最后的石头重量最小,则尽可能把石头等分为两堆。 时间复杂度: O ( m ∗ n ) O(m * n)…...
Cursor实现用excel数据填充word模版的方法
cursor主页:https://www.cursor.com/ 任务目标:把excel格式的数据里的单元格,按照某一个固定模版填充到word中 文章目录 注意事项逐步生成程序1. 确定格式2. 调试程序 注意事项 直接给一个excel文件和最终呈现的word文件的示例,…...
Leetcode 3576. Transform Array to All Equal Elements
Leetcode 3576. Transform Array to All Equal Elements 1. 解题思路2. 代码实现 题目链接:3576. Transform Array to All Equal Elements 1. 解题思路 这一题思路上就是分别考察一下是否能将其转化为全1或者全-1数组即可。 至于每一种情况是否可以达到…...

React第五十七节 Router中RouterProvider使用详解及注意事项
前言 在 React Router v6.4 中,RouterProvider 是一个核心组件,用于提供基于数据路由(data routers)的新型路由方案。 它替代了传统的 <BrowserRouter>,支持更强大的数据加载和操作功能(如 loader 和…...

Day131 | 灵神 | 回溯算法 | 子集型 子集
Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣(LeetCode) 思路: 笔者写过很多次这道题了,不想写题解了,大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...

UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...

Python实现prophet 理论及参数优化
文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候,写过一篇简单实现,后期随着对该模型的深入研究,本次记录涉及到prophet 的公式以及参数调优,从公式可以更直观…...

【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...

C++ 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...

OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在 GPU 上对图像执行 均值漂移滤波(Mean Shift Filtering),用于图像分割或平滑处理。 该函数将输入图像中的…...

Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)
目录 一、👋🏻前言 二、😈sinx波动的基本原理 三、😈波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、🌊波动优化…...