团队项目开发使用git工作流(IDEA)【精细】

目录

开发项目总体使用git流程

图解流程

1.创建项目仓库[组长完成]

2. 创建项目,并进行绑定远程仓库【组长完成】

3.将项目与远程仓库(gitee)进行绑定

3.1 创建本地的git仓库

3.2 将项目添加到缓存区

3.3 将项目提交到本地仓库,并推送到远程仓库上

4.在远程仓库上创建不同组员分支和主要分支:【组长或组员完成】

4.1 创建主要分支(dev):

5. 提交代码的流程

5.1 组员李四的开发流程

5.2 组长张三合并分支

5.2.2 组长张三拉取远程ls分支的最新代码合并到本地的dev中

5.2.3 将本地dev分支推送到远程dev分支

5.2.4 其他组员拉取最新代码


开发项目总体使用git流程

前置条件:

        1.项目团队为多人(本开发项目使用git流程案例为3人团队)

        2. gitee平台上有一个代码仓库,用于存储项目代码

        3. 仓库中有不同人的分支,外加一个主要分支dev(3人分支+dev分支=4个分支)        


流程:

        1.首先我们团队有3人(张三,李四,王五),分别对应三个分支(分支名称:zs,ls,ww)

        2.这3个人当中有一个是项目组组长(张三),组长是用来操作主要分支和自己的分支,也就是dev分支与zs分支,其余人操作各自的分支就行,组长负责自己的分支,与dev分支

        3.dev分支作用用于合并不同组员开发的不同功能代码,也就是最新代码

        4.一开是不同组员都在开发不同的功能代码,当第一个组员(李四)开发完成后,先将dev最新代码拉取到(pull)李四本地的分支上(ls)来保证自己的代码是最新的,然后再将代码提交到自己的远程分支(ls)上【本地分支与远程分支(gitee平台上的分支)】 (组员做的事情

        

        5.这时候组员(李四)告诉组长(张三),我的功能已经开发完成了,组长(张三)知道了后,切换到主要分支(dev)分支,将张三的分支(zs) 拉取到(pull)dev上,这时候的dev是最新的代码,接着如果有其他组员需要提交一定先从远程dev获取最新代码在进行提交(组长要做的事情)

图解流程

1.创建项目仓库[组长完成]

     

2. 创建项目,并进行绑定远程仓库【组长完成

3.将项目与远程仓库(gitee)进行绑定

3.1 创建本地的git仓库

3.2 将项目添加到缓存区

3.3 将项目提交到本地仓库,并推送到远程仓库上

查看远程仓库:(刷新)

远程仓库绑定成功


4.在远程仓库上创建不同组员分支和主要分支:【组长或组员完成

4.1 创建主要分支(dev):

4.2 创建小组成员的分支(zs【张三】,ls【李四】,ww【王五】)

组长张三分支(zs):

组员李四分支(ls):

组员王五分支(ww): 

返回仓库查看分支:

远程仓库创建分支完成


5. 提交代码的流程

前面已经把一个准备工作完成了,现在演示不同组员开发完成之后的一个流程

5.1 组员李四的开发流程

5.1.1  首先更新项目将分支更新一下

更新发现现在有了远程创建的所有分支

5.1.2 切换到李四的分支(ls)

只需要操作自己的分支 :【组员】               

                1.【组员】是谁,就需要切换自己的分支,比如:李四就切换到ls自己的分支,王五就切换到王五自己的分支,组员只需要操作自己的分支就可以了


操作两个分支,自己的分支和dev分支: 【组长】               

                2. 【组长】就需要操作两个分支了,因为组长需要将组员开发的代码合并到dev分支,也就是主要分支,来保证其他组员包括自己的代码在开发完成后,能够获取最新的代码,组长也有自己的分支,比如张三是组长,他也也要开发项目,所以张三也要操作zs这个分支,但是他还有一个职责就是合并其他组员开发后的代码,而dev是最新代码的分支,所以要将其他组员开发过后的代码合并到dev分支上,张三就还要操作dev分支


总结:     组员只需要操作自己的分支,组长需要操作自己的分支和dev分支

 5.1.3 组员李四进行一个项目开发

                创建controller包,并创建一个类LiSiController

5.1.4 将自己的代码提交到主要分支(dev)

                假设组员李四已经完成了开发,现在就要提交代码到远程分支

提交步骤: [李四组员的提交]

                1. 首先将李四自己开发的代码提交到本地暂存区

                2. 从dev获取最新代码,更新到李四自己的分支(不管dev有没有新代码【强制】)

                3. 最后将李四自己开发的代码提交到本地仓库,并提交到远程仓库


总体流程:

        组员李四开发代码完成---------->将代码提交到本地仓库的暂存区------------------>从远程dev分支获取最新代码合并到ls自己的分支----------------->提交代码到本地仓库ls分支上,并将代码提交到远程仓库ls分支上

1. 首先将李四自己开发的代码提交到本地暂存区

2. 从远程dev获取最新代码,更新到李四自己的本地ls分支上(不管远程dev有没有新代码【强制】)

不管远程dev有没有最新的代码,都pull一下,这样可以保证不会出错

这里是从远程dev 分支获取最新代码:

3. 最后将李四自己开发的代码提交到本地仓库ls分支上,并提交到远程仓库ls分支上

 查看一下远程仓库:

查看一下本地仓库的提交:

这个时候组员李四一个操作流程就ok了,他只需要将自己的代码提交到本地仓库,在将自己的代码提交远程自己的分支就行了,组员李四在告诉一下组长,自己已经提交了新的功能,让组长合并一下最新代码到dev,合并完成了之后,其他组员如果开发完成了,则先提交自己的代码到本地的暂存区,然后从【远程】dev拉取最新代码到组员自己的分支上,最后在提交到dev分支,整体都是这样一个流程

组员李四提交完成!!!


5.2 组长张三合并分支

上面组员李四提交自己的代码到远程分支ls上,但远程dev并没有组员李四最新的代码,这个时候组长张三就需要将这个远程ls分支中的代码合并到远程dev分支上,来保证其他组员可以获取最新的代码

5.2.1 组长张三切换到dev分支

发现并没有组员李四提交的最新代码:

5.2.2 组长张三拉取远程ls分支的最新代码合并到本地的dev中

上面本地的dev已经有了李四开发后的最新代码了,但是这最新的代码只是存在本地上,远程仓库的dev分支还并没有李四开发后的最新代码,所以其他组员并不能拉取最新的代码,我们需要将这个最新的代码推送到远程dev分支上

5.2.3 将本地dev分支推送到远程dev分支

查看远程dev分支:

远程分支记录是不是有李四的提交记录了

当组长合并代码完成后就可以不用管dev分支了,在切回组长自己的分支zs继续开发代码

5.2.4 其他组员拉取最新代码

组员王五拉取最新代码,先切换ww分支

远程dev分支获取最新代码到本地ww分支 

本地ww分支有了其他组员开发的最新代码了


最后总结:

          1. 组长操作两个分支,一个是自己的分支,一个是dev分支,自己的分支用于开发代码,dev分支用于合并其他组员远程分支上的代码包括自己的远程分支上的代码,但这时候的合并只是合并到本地的dev分支上,接着要将合并好的本地dev分支推送到远程的dev分支上,这样组员才能从远程的dev拉取最新的代码到自己的本地分支上


           2. 组员操作1个分支,先从远程dev分支获取最新代码合并到自己的本地分支上,然后在提交本地分支和远程分支就可以了

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【光谱特征选择】连续投影算法SPA(含python代码)

目录 一、背景 二、代码实现 三、项目代码 一、背景 连续投影算法(Successive Projection Algorithm,SPA)是一种用于光谱分离的简单且有效的算法。它主要应用于高光谱图像处理,用于提取混合光谱数据中的端元(endme…

从1.0到4.0,看看你公司的费控模式是第几代?

早在2021年9月,艾媒咨询在《2021H1企业费控报销服务专题研究报告》中,第一次对企业费用管控模式的进化历程进行了清晰的划代:1.0手工模式、2.0网报模式、3.0移动报销模式、4.0智能费控模式。 2022年,在《中国企业费用管理发展白皮…

边缘计算网关:企业数字化转型的重要支撑-天拓四方

在数字化浪潮席卷全球的今天,企业对于数据处理和传输的需求日益增强。然而,传统的数据处理模式往往依赖于中心化的数据中心,这种方式在处理大量数据时存在延迟高、成本高、安全性差等问题。数据量的激增和实时性要求的提高,使得传…

6个迹象表明你的电脑电缆管理很糟糕,看下你有没有中招

​清理电脑内部的电缆可能看起来像是徒劳的忙碌。毕竟,如果一切都正常,为什么还要麻烦呢?好吧,我有六个很好的理由可以说服你打开你的机箱,修复你电脑里的混乱。 你很难打开侧板 如果你的电缆离侧板的边缘太近,你将无法毫不费力地将它们滑开。虽然这不是你每天都要做的…

AUTOSAR术语表

AUTOSAR术语表 下面所有的缩写词汇均来自AUTOSAR官方资料AUTOSAR_TR_GLOSSARY.pdf,平常工作中遇到不知道意思的缩略词,编写代码取名称时都可以参考这个术语表。

vscode搭建esp-idf的esp32开发环境

一、安装esp-idf-tools-setup-offline-4.4.7 https://docs.espressif.com/projects/esp-idf/zh_CN/v5.1/esp32/get-started/windows-setup.html 二、vscode安装插件 ESP-IDF 安装完成点击左侧的图标 会自动查找系统中安装的ESP-IDF 自动完成配置 不成功的话 试着完成下面的操作…

Ubuntu server 24 (Linux) sudo 免输密码

1 sudo 使用要输入密码,费时费力。 2 sudo命令免输密码,需要修改/etc/sudoers文件 #本文以test用户为例,#允许不需要输入密码执行 sudo vi /etc/sudoers test ALL(ALL) NOPASSWD: ALL %sudo ALL(ALL:ALL) ALL --> #%sudo ALL(ALL:ALL) ALL#所有…

使用Python操作Redis

大家好,在当今的互联网时代,随着数据量和用户量的爆发式增长,对于数据存储和处理的需求也日益增加。Redis作为一种高性能的键值存储数据库,以其快速的读写速度、丰富的数据结构支持和灵活的应用场景而备受青睐。本文将介绍Redis数…

【猫狗识别系统】图像识别Python+TensorFlow+卷积神经网络算法+人工智能深度学习

猫狗识别系统。通过TensorFlow搭建MobileNetV2轻量级卷积神经算法网络模型,通过对猫狗的图片数据集进行训练,得到一个进度较高的H5格式的模型文件。然后使用Django框架搭建了一个Web网页端可视化操作界面。实现用户上传一张图片识别其名称。 一、前言 …

[第五空间 2021]WebFTP、[HCTF 2018]Warmup

目录 [第五空间 2021]WebFTP ​[SWPUCTF 2021 新生赛]Do_you_know_http [NCTF 2018]签到题 [HNCTF 2022 Week1]What is Web [HNCTF 2022 Week1]Interesting_http [HCTF 2018]Warmup [第五空间 2021]WebFTP 使用dirsearch扫描,发现有git泄露 使用GitHack克隆目…

Docker以挂载方式安装RocketMQ

Docker 挂载安装RocketMQ Docker 挂载安装RocketMQ安装 Docker安装NameServer1.拉取容器2.创建NameServer容器3.查看容器状态4.补充配置4.1交互模式启动Docker容器4.2编辑broker.config4.2插入brokerIP1配置 安装Broker安装RocketMQ-console构建镜像启动容器开通安全组策略访问…

【Godot4自学手册】第四十一节背包系统(一)UI设置

各位同学,好久没有更新笔记了,今天开始,我准备自学背包系统。今天先学习下UI界面设置。 一、新建场景和结点 1.新建Node2D场景,命名为Inventory,保存到Scenes目录下,inventory.tscn。 2.新建TextureRect子…

寒武纪:“国产平替”道阻且长

英伟达的一季报反映了AI装备竞赛白热化,科技巨头们正疯狂加码投资。 不过,因为众所周知的原因,英伟达最先进的产品卖不到国内,虽然说一定程度上限制了咱们AI的发展,但也给国产AI芯片公司们提供了机会,其中就包括我们今…

HCIA--VLAN实验(复习)

实验要求: 1.PC1/2/5 在vlan2,PC3/4/6在vlan3. 2.SW1、SW2之间,SW1、R1之间 为trunk干道, 3.PC不配地址,通过DHCP获取地址 实验思路: 1.在SW上创建vlan,在对应接口划分vlan 2.SW1、SW2,SW…

掌握 NestJS 10.x:NestJS 结合 PostgreSQL 使用详解

NestJS 是一个用于构建高效、可扩展的 Node.js 服务端应用的框架。结合 PostgreSQL 数据库,可以为应用提供强大的数据存储和查询功能。本文将详细介绍如何在 NestJS 项目中集成和使用 PostgreSQL,并创建一个包含增加用户接口的完整示例。 1. 安装必要的依赖 首先,确保你的…

七校联赛题铅笔姿态及笔迹检测装置--mpu6050识别数字

前言 前几天打完比赛,收获还是挺大的,数字识别部分基本上浪费了绝大部分时间。先将思路简单说明。 1、题目 2、思路 针对笔迹检测,我们首先考虑的肯定是陀螺仪来测量加速度方向来判断书写的方向,从而得到书写的数字。 我们的方案…

【活动感想】CSDN技术沙龙之人工智能的日常应用与技术分享

目录 🌊1. 会议详情 🌞2. 会议感想 🏞️3. 会议总结 🌊1. 会议详情 主持人: 大家好,欢迎各位参加我们今天的小型技术沙龙活动!今天我们将围绕人工智能的日常应用与技术分享展开讨论。人工智…

kaggle:房价预测

比赛链接 结果展示 结果链接 8848是密码 文章目录 数据处理调包部分拒绝掉包岭回归理论代码实践结果 自助采样理论代码 集成学习前言Bagging理论Bagging代码Bagging-Ridge实践Bagging-Ridge结果 Tricks 数据处理 #打开文件 import pandas as pd dataset1pd.read_csv("tr…

CANDela studio的State

State主要用来查看,点击State Groups,可以看到session和security下面有多少个会话和security level,所以删除和新建都不能在这里操作。 Dependencies没有安装插件,看不到图形不要紧,点击下面那个图标,就能编…