JetBrains IDE 使用git进行多人合作开发教程

以下DEMO可以用于多人共同开发维护一个项目时,使用Git+远程仓库的实践方案

分支管理

  • dev:开发分支
  • test:测试分支
  • prod:生成分支

个人开发也最起码有一个master+dev,作为主分支和当前开发分支。master永远是稳定版本,dev用于写代码测试都行。确保dev没问题再合并到master


Git工作流

  • 开发人员在个人新建的特性分支上工作,完成后将特性分支合并到 dev 分支。
  • 定期将 dev 分支的代码合并到 test 分支进行测试。
  • 测试通过后,将 test 分支的代码合并到 prod 分支,并部署到生产环境。



  • 先拉取远程最新分支到本地



  • Local处New Branch from ‘main’… 从main主分支创建新分支
    [图片]

  • 勾选Checkout branch,创建后默认会切换到创建的新test分支
    [图片]

  • 输入本地分支名称后可以在Local看到刚创建的分支(本地的项目分支)
    [图片]

  • 点击左侧提交,可以查看更改文件,双击查看对比
    [图片]

  • 勾选需要提交的文件,输入本次版本提交名称,点击提交并推送
    [图片]

  • 弹窗后,点击推送
    [图片]

  • 登陆仓库平台的提交账号
    [图片]

  • 登陆后,去仓库查看提交记录
    [图片]

  • PS:Logo解释
    [图片]


代码更新

  • 点击Update更新远程最新分支到本地的个人的test项目分支上
    [图片]

实战演示

  • 模拟远程分支更新了最新状态,进入仓库首页,点击新建文件
    [图片]

  • 在根目录下新建 B.go,随便写入一些东西。最后点击保存到主分支中
    [图片]

  • 查看远程与本地的变化
    [图片]

假设此时这个B.go是程序员已经写完一个功能,进行提交。他将远程分支新增了一个版本。而你也就落后了一个版本。因此很明显你本地和远程的代码就不一样。

你本地有A.go,而远程没有
远程有B.go,你本地没有

  • 将代码添加暂存区并提交推送
    [图片]
    [图片]

  • 提示:当前推送被远程拒绝,在推送前需要合并远程最新的更改
    [图片]

点击Merge进行合并即可,正常来说,你新增了一个文件B,远程别人新增了一个文件C并且已经更改到最新的分支。此时你已经落后别人一个版本。而你们对于其他任何文件都没有动的话,是没有事儿的。就直接取并集合并了。

  • 提示合并提交成功
    [图片]

  • 上一步骤说的取并集是什么意思呢?
    [图片]

可以看到这张图,你本地的A提交到了仓库的最新分支
同时,你落后的那个版本,别人提交的B也到了你的本地仓库

PS:其实这里做了几个事儿,首先会比对你的上一个基础分支与远程的区别。然后拉取远程的最新分支,将你的本地分支更新到最新状态。如果此时有代码冲突IDE会提示你需要保留本地还是远程。

如果你写你的代码,不动别人的代码,正常来说是没有冲突的。(前期是你两不会同时写一个文件,同时用一个分支)

此时只会更新别人刚写好的的模块。然后你本地就是远程最新分支 + 你本地新写的东西

然后IDA会给你将你本地的最新代码做为一个新的版本提交到最新的仓库的主分支,以此完成本次合并分支


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

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

相关文章

花几千上万学习Java,真没必要!(十九)

1、StringBuilder: 测试代码1: package stringbuilder.com; import java.util.ArrayList; import java.util.List; public class StringBuilderExample { public static void main(String[] args) { // 初始化StringBuilder StringBuilder sb n…

腾讯会议产品策划的成长之路:从万字文档到功能落地的实战经验

腾讯会议产品策划的成长之路:从万字文档到功能落地的实战经验 在腾讯会议的产品团队中,有这样一位产品策划,他以其出色的逻辑思维、全局观念以及扎实的执行力,在团队中发挥着举足轻重的作用。他就是林陪同,一个自称“会…

css font 优化

文章目录 使用 font-display 控制字体加载预加载关键字体选择合适的字体文件类型按需创建字体文件HTTP 缓存优化 使用 font-display 控制字体加载 避免字体加载导致的空白 block:浏览器在短暂的阻塞期内不显示任何文本,直到字体加载完成。这可能导致页…

JAVA进阶学习12

文章目录 一、File类1.1 File对象的构造1.2 File对象的常见方法判断功能的方法获取功能的方法绝对路径和相对路径创建删除功能的方法 1.3 File的常用遍历方法1.4 File获取并遍历的其他方法1.5 用法举例二、IO流2.1 IO的分类2.2 字节流的方法概述2.2.1 FileOutputStream2.2.2 Fi…

如何配置Memcached以减少对数据库的直接访问

如何配置Memcached以减少对数据库的直接访问 1. 引言 在现代应用程序中,数据库通常是性能瓶颈的主要来源之一。通过使用Memcached,开发者可以显著减少数据库的负载,提高应用程序的响应速度。本文将详细介绍如何配置Memcached,以…

UE4-字体导入

一.字体导入 方法一: 然后通过导入将自己想要的字体导入到项目中,也可以直接将我们放在桌面的字体直接拖入到我们的内容浏览器中。 但是要注意想要发售游戏的话不可以这样导入微软的字体,因为Windows自带基本都有版权,所以最…

odoo17创建一个默认UI视图

XML 数据文件 当要加载的数据具有简单格式时,CSV 格式很方便。当格式更复杂时(例如,加载视图或电子邮件模板的结构),我们使用 XML 格式。例如,此帮助字段包含 HTML 标记。虽然可以通过 CSV 文件加载此类…

明星应援系统小程序的设计

管理员账户功能包括:系统首页,个人中心,用户管理,线上应援管理,线下应援管理,应援物品管理,购买订单管理,集资应援管理,集资订单管理,市集订单管理&#xff0…

极致竞争思维

老板请了几个毕业生,培训了一年,他们现在对业务的熟悉程度比我都熟悉多了,只是基本功不扎实,做出来的东西有很多问题。 老板请我来,给了我一个硬件总监的位置,实际上是要对他的整个系统做出诊断。 也是难为…

【QT】线程控制和同步

目录 概述 QThread常用API 线程使用 创建一个QThread的子类 主线程启动线程 线程安全 互斥锁 QMutex 使用示例:两个线程一个共享静态变量进行 线程子类创建 主线程调用 QMutexLocker 条件变量 信号量 概述 在 Qt 中,多线程的处理⼀般是…

【CSS in Depth 2 精译_020】3.3 元素的高度

当前内容所在位置(可进入专栏查看其他译好的章节内容) 第一章 层叠、优先级与继承(已完结) 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位(已完结) 2.1 相对…

【proteus经典实战】定时器控制交通灯指示灯

一、简介 基于8051系列单片机实现,旨在模拟一个简单的交通灯系统,实现红、黄、绿灯的交替亮灭。使用了特殊功能寄存器(SFR)和位操作来控制硬件,使用定时器0的中断功能来控制交通灯信号的切换。通过软件控制&#xff0…

解决selenium打印保存为PDF时图片未加载成功的问题

使用selenium打印网页时,如果程序运行很快的话,可能会导致图片没有加载成功即进行了保存,出现这个问题最初的思考是在执行打印任务时使用js进行强制等待,后发现实现效果并不好。在加载页面时使用自动下滑的方式将网页拉到底&#…

uniapp动态计算并设置元素高度

<template><view><scroll-view id"sv-box" :scroll-y"true" :style"{height:navHeightpx}"></scroll-view><view id"btn-box"><button>取消</button><button>确认</button><…

Linux Vim教程(三):插入模式与命令模式

目录 1. Vim的基本模式介绍 2. 插入模式 2.1 进入插入模式 2.2 退出插入模式 2.3 插入模式下的快捷键 2.4 插入模式中的光标移动 3. 命令模式 3.1 进入命令模式 3.2 常用命令 3.3 搜索和替换 3.4 其他有用的命令 3.5 配置与优化 3.5.1 自动补全 3.5.2 自定义快捷…

【前后端联调】HttpMessageNotReadableException

【前后端联调】HttpMessageNotReadableException 01 问题描述 在前后端联调时产生的问题&#xff0c;关键是下面这句翻译JSON解析错误&#xff1a;无法构造“java.util.ArrayList”的实例 org.springframework.http.converter.HttpMessageNotReadableException: JSON parse …

记录贴-NGINX相关

链接: NGINX相关配置信息说明

在 CI/CD 中怎么使用 Docker 部署前端项目?

本项目代码已开源&#xff0c;具体见&#xff1a; 前端工程&#xff1a;vue3-ts-blog-frontend 后端工程&#xff1a;express-blog-backend 数据库初始化脚本&#xff1a;关注公众号程序员白彬&#xff0c;回复关键字“博客数据库脚本”&#xff0c;即可获取。 前言 在上一篇文…

Web Pages 表单

Web Pages 表单 介绍 Web pages 表单是现代网页设计中不可或缺的组成部分&#xff0c;它们允许用户与网站进行交互&#xff0c;提交信息&#xff0c;如注册、登录、反馈、预订等。表单的设计和功能对用户体验和网站的业务目标有着直接的影响。本文将深入探讨Web pages表单的各…

快速上手AI指令:打造个性化智能交互体验的全面指南

快速上手AI指令&#xff1a;打造个性化智能交互体验的全面指南 一、初识文心一言1.1 文心一言简介1.2 文心一言的特点 二、准备工作2.1 获取访问权限2.2 熟悉界面布局2.3 了解基础指令 三、基础指令操作3.1 问答互动3.2 文本创作3.3 任务规划 四、进阶指令操作4.1 复杂查询4.2 …