GIt的原理和使用(五):模拟多人协作的两种情况

目录

多人协作

多人协作一

准备工作 

 协作开发

多人协作二

准备工作

额外场景

申请单合并分支

更推荐写法 

远程分支删除后,本地git branch -a依然能看到的解决办法


多人协作

多人协作一

  • 目标:在远程master分支下的file.txt文件新增代码“aaa”和“bbb”
  • 实现:由开发者1新增“aaa”,由开发者2新增“bbb”
  • 条件:在一个分支下协作完成

准备工作 

1、在远程仓库中创建一个dev分支(远程分支,很推荐)

2、令linux中的开发者1获取新建的dev分支

  • git branch -r:只显示哪些远程分支已经被拉取到了本地
  • git branch -a:列出所有的分支,包括本地分支和远程分支,如果一个远程分支被拉取到了本地,它将以类似 remotes/origin/branch_name 的形式显示在列表中

3、在windows环境下clone一个和linux中开发者1一样的仓库,模拟开发者2:

        ①D盘新建一个空的git文件夹,进入文件夹,在空白处按住shift+鼠标右键,选择在此处打开PowerShell窗口:

② 将远程仓库克隆给一份给它

 协作开发

1、开发者1在其本地创建一个dev分支,在将该分支切换为工作分支后与远程dev分支建立连接

  • git checkout -b 本地分支名 远程分支名
  • git branch -vv:显示本地分支列表以及每个分支的跟踪信息

2、修改file.txt文件,向其中新增aaa并提交给本地仓库的dev分支

3、将开发者1的本地dev分支提交给远程dev分支 

出现以下界面可以用git config --global push.default matching指令解决:

提交成功: 

4、开发者2在其本地创建一个dev分支,在将该分支切换为工作分支后与远程dev分支建立连接

5、在记事本上修改file.txt文件,新增bbb

6、尝试将开发者2的本地dev分支提交给远程dev分支 

  • 原因:冲突问题,二者都将file.txt文件新增内容提交给远程仓库,远程仓库不知道要用谁的

7、人工解决冲突问题并再次提交(对远程dev分支与当前dev分支合并后出现的冲突进行修改)

8、向远程dev分支推送成功(此时远程master分支中的file.txt文件仍未被修改)

9、合并远程的dev分支和master分支 

远程操作: 

本地操作: 

①将本地dev更新至最新(如果不更本地dev的file.txt没有新增bbb)

②切换至本地master并令本地master为最新状态

如果不更新的话,如果远程master中有ccc但是此时本地master没ccc,在本地master合并了本地dev后进行提交时,该master也没有ccc 

③切换至本地dev,并合并本地master(由于什么都没干所以中间有些内容是没啥东西的)

  • 原因:这样有了冲突也可以在dev上进行修改,直接在master上修改有风险

④切换至本地master,并合并本地dev,最后将合并后的master提交给远程master

⑤查看远程仓库的master分支中的file.txt文件(已被修改)

⑥删除远程dev分支

多人协作二

  • 目标:远程master分支下新增function1和function2文件
  • 实现:由开发者1新增function1,由开发者2新增function2
  • 条件:在不同分支下协作完成

准备工作

①开发者1创建一个feature-1分支,并切换至该分支,同时在该分支下创建并编写function1文件

②将本地feature-1分支推送至远程仓库

本地与远程仓库建立连接的三种方式:(②时的远程仓库中没有设置分支所以后两种方法不能用)

  • git push origin 本地分支名:强制推送本地分支至远程仓库
  • git checkout -b 本地分支名 远程分支名:切换至本地分支时就将该分支与远程分支建立连接
  • git branch -u origin/远程分支名 本地分支名:单纯的将本地分支和远程分支建立连接

③保证开发者2的master分支是最新的版本

④开发者2创建一个feature-2分支,并切换至该分支,同时在该分支下创建并编写function2文件

  • 新建function2文件时直接在对应文件夹下创建function2文本文件即可 

至此已完成初始目标 

额外场景

问题:开发者2生病,开发者1要接替开发者2的工作

①开发者1从远程仓库中获取开发者2的工作内容

对应git pull:

  • 拉取分支中的内容时需要将两个分支建立连接后才能拉取
  • 可以直接拉取仓库内容

②开发者1创建feature-2分支,并切换至该分支,同时将该分支与远程仓库中的feature-2分支连接

③开发者1帮助开发者2继续开发他的function2文件,同时提交至本地feature-2分支 

④将本地feature-2分支更新的内容推送到远程feature-2分支中 

新问题:此时开发者2病好了申请继续开发

①开发者2获取远程仓库中开发者1写了一部分的feature-2分支的内容(不拉就还是一行coding)

② 开发者2完成对function2文件的开发

申请单合并分支

管理者进行审批: 

 

更推荐写法 

        虽然申请单的方式看起来很方便,但是为了防止冲突问题,我们更推荐在副分支上将该副分支与主分支合并后(有冲突问题就解决)再将该分支与主分支合并的方式:

①将开发者1的master分支更新至最新:

② 合并本地的feature-1分支和master分支,如果两个分支没有冲突就会显示以下界面

③查看本地feature-1分支是否与远程的feature-1分支连接

④强制将开发者1的本地feature-1分支推送给远程仓库(新修改的内容覆盖远程的)

⑤提交申请表单申请将远程feature-1分支与远程master分支合并

 ⑥删除远程的feature-1和-2分支 

远程分支删除后,本地git branch -a依然能看到的解决办法

在删除远程仓库的feature-1和feature-2分支后,远程仓库中只有master分支了:

但是此时我们在开发者中使用git branc -a依然能看到原来的feature-1和feature-2分支:

展示远程分支情况指令:git remote show origin

清理无用远程分支:git remote prune 指令名 远程仓库分支名(git branch -a时不会显示)

最后用git branch -d 分支名删除本地的无用分支即可

~over~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/782618.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

鸿蒙OS开发实例:【窥探网络请求】

HarmonyOS 平台中使用网络请求,需要引入 "ohos.net.http", 并且需要在 module.json5 文件中申请网络权限, 即 “ohos.permission.INTERNET” 本篇文章将尝试使用 ohos.net.http 来实现网络请求 场景设定 WeiBo UniDemo HuaWei : 请求顺序WeiBo1 UniDem…

华为数通 HCIP-Datacom H12-831 题库补充(3/27)

2024年 HCIP-Datacom(H12-831)最新题库,完整题库请扫描上方二维码,持续更新。 如图所示,关于R4路由器通过IS-IS计算出来的IPv6路由,哪一选项的描述是错误的? A:R4通过IS—IS只学习到…

基于SpringBoot的“校园台球厅人员与设备管理系统”的设计与实现(源码+数据库+文档+PPT)

基于SpringBoot的“校园台球厅人员与设备管理系统”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:SpringBoot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 系统功能结构图 系统首页界面图…

PCL拟合并绘制平面(二)

使用RANSAC拟合点云平面 1、C实现2、效果图 普通的点云平面拟合方式在一般情况下可以得到较好的平面拟合效果,但是容易出现平面拟合错误或是拟合的平面不是最优的情况。此时就需要根据自己的实际使用情况,调整平面拟合的迭代次数以及收敛条件。 使用RAN…

亚马逊测评新策略:解决底层环境防关联,提升下单成功率

对于做测评的环境系统,确保稳定性和成功率是非常重要的。市面上有各种环境方案,如虚拟机、模拟机、gcs、云手机、VPS等。然而,这些方案不仅成本高,而且成功率很低。因此,一个好的环境系统是成功的基础。 亚马逊平台的…

记录rocketMQ5.+启动报错解决过程

1.根据官方文档指引下载对应的rocketMQ源码包,上传到服务器解压 2. 启动NameServer nohup sh bin/mqnamesrv & 验证namesrv是否启动成功 tail -f ~/logs/rocketmqlogs/namesrv.log The Name Server boot success… 3.启动BrokerProxy nohup sh bin/mqbroker -n …

第3章.引导ChatGPT精准角色扮演:高效输出专业内容

角色提示技术 角色提示技术(role prompting technique),是通过模型扮演特定角色来产出文本的一种方法。用户为模型设定一个明确的角色,它就能更精准地生成符合特定上下文或听众需求的内容。 比如,想生成客户服务的回复…

Java作业3-字符串

题目一 代码 import java.util.*; public class Main {public static void main(String[] args) {Scanner input new Scanner( System.in );String str input.nextLine();int len str.length();StringBuilder s new StringBuilder(len);//StringBuilder类参考菜鸟教程for…

深入理解HDFS工作原理:大数据存储和容错性机制解析

** 引言: ** 在当今数据爆炸的时代,存储和管理大规模数据成为了许多组织面临的重要挑战。为了解决这一挑战,分布式文件系统应运而生。Hadoop分布式文件系统(HDFS)作为Apache Hadoop生态系统的核心组件之一&#xff…

是德科技keysight N9000B 信号分析仪

181/2461/8938产品概述: 工程的内涵就是将各种创意有机地联系起来,并解决遇到的问题。 CXA 信号分析仪具有出色的实际性能,它是一款出类拔萃、经济高效的基本信号表征工具。 它的功能十分强大,为一般用途和教育行业的用户执行测试…

深入探讨分布式ID生成方案

✨✨谢谢大家捧场,祝屏幕前的小伙伴们每天都有好运相伴左右,一定要天天开心哦!✨✨ 🎈🎈作者主页: 喔的嘛呀🎈🎈 ✨✨ 帅哥美女们,我们共同加油!一起进步&am…

vue3数据库中存头像图片相对路径在前端用prop只能显示路径或无法显示图片只能显示alt中内容的问题的解决

不想看前情可以直接跳到头像部分代码 前情: 首先我们是在数据库中存图片相对路径,这里我们是在vue的src下的assets专门建一个文件夹img存头像图片。 然后我们如果用prop"avatar" label"头像"是只能显示图片路径的,即lo…

java数组与集合框架(一) -- 数据结构,数组

数据结构 概述 为什么要讲数据结构? 任何一个有志于从事IT领域的人员来说,数据结构(Data Structure)是一门和计算机硬件与软件都密切相关的学科,它的研究重点是在计算机的程序设计领域中探讨如何在计算机中组织和存储…

ctfshow web入门 XXE

XXE基础知识 XXE(XML External Entity)攻击是一种针对XML处理漏洞的网络安全攻击手段。攻击者利用应用程序在解析XML输入时的漏洞,构造恶意的XML数据,进而实现各种恶意目的。 所以要学习xxe就需要了解xml xml相关: …

计算数组元素中每个元素与其之前各元素的累积乘积ndarray.cumprod()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 计算数组元素中每个元素 与其之前各元素的累积乘积 ndarray.cumprod() 选择题 关于以下代码输出的结果说法正确的是? import numpy as np a np.array([2,4,6]) print(【显示】a ,…

彩虹外链网盘界面UI美化版超级简洁好看

彩虹外链网盘界面UI美化版 彩虹外链网盘,是一款PHP网盘与外链分享程序,支持所有格式文件的上传,可以生成文件外链、图片外链、音乐视频外链,生成外链同时自动生成相应的UBB代码和HTML代码,还可支持文本、图片、音乐、…

Diffusion添加噪声noise的方式有哪些?怎么向图像中添加噪声?

添加噪声的方式大致分为两种,一种是每张图像在任意timestep都加入一样的均匀噪声,另一种是按照timestep添加不同程度的噪声 一、在任意timestep都加入一样的noise batch_size 32x_start torch.rand(batch_size,3,256,256) noise torch.randn_like(x_…

XUbuntu22.04之激活Linux最新Typora版本(二百二十五)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒…

技巧 Win10电脑打开SMB协议共享文件,手机端查看

一. 打开 SMB1.0/CIFS文件共享支持 ⏹如下图所示,打开SMB1.0/CIFS文件共享支持 二. 开启网络发现 ⏹开启网络发现,确保共享的文件能在局域网内被发现 三. 共享文件夹到局域网 ⏹根据需要勾选需要共享的文件夹,共享到局域网 四. 共享文件查…

Linux重点思考(下)--shell脚本使用以及内核开发

Linux重点思考(下)--shell脚本使用和组合拳 shell脚本的基础算法shell脚本写123...n的值,说思路Shell 脚本用于执行服务器性能测试的死循环Shell 脚本备份和定时清理垃圾文件 shell脚本的内核开发正向映射反向映射 shell脚本的基础算法 shell脚本写123……