当前位置: 首页 > news >正文

【Git多人开发与协作之团队的环境搭建】

Git多人开发与协作之团队的环境搭建

    • 新的改变
    • 1. Git 的用途
    • 2. 分支的概念与类型
    • 3. HEAD 和分支指针
      • 如何查看 HEAD 指向的位置:
    • 4. 常见的 Git 操作
    • 5. 常见问题与解决方法
    • 总结
    • GitHub 项目获取实操
    • 在新电脑上运行 Git
      • 1. 安装 Git
      • 2. 配置用户名和邮箱
      • 3.配置 Git 和 SSH 密钥
      • 4.生成 SSH 密钥
    • 如何在idea上完成git的使用:

新的改变

最近要完成我们的小组作业了,对此我觉得做一些新的尝试,比如教会团队人员如何正确使用 Git 来实现代码的多人协作,提高开发效率,提升个人能力。这对于我们这样的大学生还颇具挑战的,不过对于我来说这是一个有趣的东西,我并不渴望从中获得什么,我只是单纯的体验这种快乐,享受 coding 的乐趣。

1. Git 的用途

Git 是一个分布式版本控制系统,主要用于管理代码的变更。其主要功能是:

  • 跟踪代码变更:每次修改都能被记录下来,并且可以随时回退到以前的版本。
  • 多人协作:Git 允许多个开发者同时在同一个项目上工作,通过分支和合并的方式避免冲突。
  • 代码分支管理:通过分支,团队可以独立开发不同的功能或修复不同的 bug,而不影响主代码库。

2. 分支的概念与类型

在 Git 中,分支(Branch) 是用来独立开发不同功能的工具。分支使得我们能够在不干扰主开发流程的情况下进行开发。

  • 本地分支(Local Branch): 本地分支是你在自己的开发环境中创建和操作的分支。例如,你可能会创建一个 feature/login 分支来开发登录功能,开发完成后再合并到主分支。
  • 远程分支(Remote Branch): 远程分支是在 Git 仓库服务器上存在的分支,通常由团队成员共享。origin/main 就是 Git 默认的远程主分支名。
  • 多个分支开发: 在多人开发的场景中,每个人可以在自己的分支上进行开发。例如,一个成员负责前端功能的开发,另一个成员负责后端 API 的开发。这些分支开发完成后,可以通过 Pull Request(PR)合并到 develop 分支中进行集成,最后合并到 main 分支发布。

3. HEAD 和分支指针

HEAD 是 Git 中的一个指针,它指向当前所在的分支和提交。可以认为 HEAD 是你当前工作的“游标”。

例如,当你切换到 feature/login 分支时,HEAD 会指向该分支的最新提交。

如何查看 HEAD 指向的位置:

  • 使用 git status 查看当前分支。
  • 使用 git log 查看历史提交记录,确认 HEAD 指向的提交。

4. 常见的 Git 操作

  • 创建本地分支并切换到该分支
    git checkout -b <branch_name>
    
  • 查看本地和远程分支
    git branch        # 查看本地分支
    git branch -r     # 查看远程分支
    
  • 切换分支
    git checkout <branch_name>
    
  • 合并分支:当开发完成后,可以通过合并操作将当前分支的改动合并到主分支(如 develop):
    git merge <branch_name>
    
  • 推送分支到远程仓库
    git push origin <branch_name>
    
  • 拉取远程分支到本地
    git pull origin <branch_name>
    

5. 常见问题与解决方法

  • 分支合并冲突:合并分支时可能会出现代码冲突。Git 会提示你哪个文件有冲突,你需要手动解决冲突,修改文件后提交:
    git status         # 查看冲突文件
    # 编辑文件,解决冲突
    git add <file_name>  # 标记冲突已解决
    git commit         # 提交修改
    
  • 如何撤销更改:如果你在修改文件时遇到问题,可以撤销对文件的更改:
    git checkout -- <file_name>  # 撤销对某个文件的修改
    git reset --hard             # 撤销所有更改(注意:此命令会丢失所有未提交的更改)
    

总结

Git 是一个高效的开发工具,我们可以给团队的每个人员配置好编译环境和 Git 环境后,每个人员拥有一个本地分支,来更新和获取远程分支的内容,了解现在团队的代码开发进度,或者通过 Git 回溯到之前开发的代码内容。通过 Git 每个人可以开发不同的功能,页面,然后通过 Git 来合并分支,完成多个人共同开发不同的功能。

因此我们需要一个远程分支,来表示我们当前项目的总的开发进度,再使用一个远程分支表示我们测试的进度,我们会在这上面去合并我们已经开发的新功能,在本地我们每个人会开发不同的功能,进行测试和验证。通过 GitHub 可以看到不同的分支内容。

因此正确的方式是每个人的本地分支,推送到远程测试分支上,完成单个或者多个功能的合并更新,验证没有问题后由主要开发人员更新到项目分支上。

GitHub 项目获取实操

为了方便大家获取到我已经上传的 GitHub 文件,我建立了一个 GitHub 仓库,大家可以下载:

https://github.com/yearsGG/2024GUC_xz_vue-sbringboot_shangdian

或者通过命令行(cmd)直接使用命令:

git clone git@github.com:yearsGG/2024GUC_xz_vue-sbringboot_shangdian.git

展示图片

在新电脑上运行 Git

1. 安装 Git

首先,我们需要下载并安装 Git。可以通过 Git 的官方网站进行下载:

Git 下载官网

安装完成后,可能需要配置环境变量。

2. 配置用户名和邮箱

在命令行上配置用户名和邮箱,以便提交时使用:

git config --global user.name "Your Name"
git config --global user.email "your_email@example.com"

3.配置 Git 和 SSH 密钥

配置完成后,执行以下命令,确保设置正确:

git config --list

4.生成 SSH 密钥

如果你没有现成的 SSH 密钥,可以按以下步骤生成:

ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

添加 SSH 公钥到 GitHub
生成完 SSH 密钥后,你需要将公钥添加到 GitHub 账户(可能需要你去创建github账户)。

打开公钥文件:~/.ssh/id_rsa.pub,复制文件内容。
登录 GitHub,进入 Settings -> SSH and GPG keys -> New SSH key。
粘贴复制的公钥,并保存。
测试 SSH 连接
用以下命令测试连接 GitHub:

ssh -T git@ssh.github.com -p 443

注意这里问yes或者no的时候一定要打yes。
如果一切正常,GitHub 会返回类似的消息:

Hi <username>! You've successfully authenticated, but GitHub does not provide shell access.

如何在idea上完成git的使用:

在idea上面打开之前命令行下载好的文件,你会看到下面的页面:
在这里插入图片描述
点开版本控制有如下截图:
在这里插入图片描述
这里可以看到你的基友的开发进度,当然前提是你要获取最新的内容(使用idea自带的终端就可以了):

git pull

相关文章:

【Git多人开发与协作之团队的环境搭建】

Git多人开发与协作之团队的环境搭建 新的改变1. Git 的用途2. 分支的概念与类型3. HEAD 和分支指针如何查看 HEAD 指向的位置&#xff1a; 4. 常见的 Git 操作5. 常见问题与解决方法总结GitHub 项目获取实操在新电脑上运行 Git1. 安装 Git2. 配置用户名和邮箱3.配置 Git 和 SSH…...

java基础概念36:正则表达式1

一、正则表达式的作用 作用一&#xff1a;校验字符串是否满足规则&#xff1b;作用二&#xff1a;在一段文本中查找满足要求的内容。——爬虫 二、正则表达式 2-1、字符类 示例&#xff1a; public static void main(String[] args) {System.out.println("a".matc…...

java实现小程序接口返回Base64图片

文章目录 引言I java 接口返回Base64图片接口设计获取验证码图片-base64字符串获取验证码图片-二进制流arraybufferII 小程序端代码过期代码: 显示文件流图片(arraybuffer)知识扩展:微信小程序下载后端返回的文件流引言 场景: 图形验证码 背景: 接口返回arraybuffer的格式…...

网络编程并发服务器的应用

作业2&#xff1a;完成局域网CS模型&#xff0c;局域网内一个服务器&#xff0c;多个客户端连接一个服务器&#xff0c;完成局域网聊天&#xff08;select函数&#xff0c;poll函数&#xff0c;完成TCP并发服务器&#xff09;。 poll函数应用&#xff1a; 服务器部分代码&…...

数据结构——停车场管理问题

目录 1、问题描述2、逐步分析1&#xff09;涉及操作2&#xff09;代码实现 3、代码整合 1、问题描述 1、题目 设停车场内只有一个可停放n辆汽车的狭长通道&#xff0c;且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序&#xff0c;依次由北向南排列&#x…...

道品智能科技移动式水肥一体机:农业灌溉施肥的革新之选

在现代农业的发展进程中&#xff0c;科技的力量正日益凸显。其中&#xff0c;移动式水肥一体机以其独特的可移动性、智能化以及实现水肥一体化的卓越性能&#xff0c;成为了农业领域的一颗璀璨新星。它不仅改变了传统的农业灌溉施肥方式&#xff0c;更为农业生产带来了高效、精…...

AI实习--常用的Linux命令

一、基础命令 1. 切换到根目录。 cd ~ 2. 返回上一级目录。 cd .. 3. 查看当前目录下包括哪些文件和文件夹。 ls 4. 查看当前路径。 pwd 5. 将文件或文件夹剪切到目标目录下。 mv 文件所在路径 目标路径 6. 查看文本文件内容。 cat 文本文件名 7. 创建文件或文件夹…...

Python学习指南 + 谷歌浏览器如何安装插件

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a; Python 目录 前言 Python 官方文档的使用 谷歌浏览器中如何安装插件 前言 在学习Python时&#xff0c;我们可能会出现这样的困惑&#x…...

研0找实习【学nlp】15---我的后续,总结(暂时性完结)

当下进展成果&#xff1a; nlptransformerpytorchhuggingfacebert简历环境配置表情识别文本分类 断更了快1个月&#xff0c;2个礼拜找实习&#xff0c;1个礼拜伤心&#xff0c;1个礼拜想我要干什么…… 承认自己的才疏学浅&#xff0c;了解了leetcode&#xff0c;和老师商量了…...

kylin麒麟银河桌面版操作系统安装部署

本文主要描述kylin麒麟银河桌面版操作系统的安装&#xff0c;该操作系统的安装源文件可以从kylin麒麟银河官方网站上下载&#xff0c;商业版本需要申请试用&#xff0c;开源版本可以直接下载使用。 如上所示&#xff0c;x86芯片处理器架构的请下载INTEL版本&#xff0c;华为海思…...

MyBatis插件原理及应用

&#x1f3ae; 作者主页&#xff1a;点击 &#x1f381; 完整专栏和代码&#xff1a;点击 &#x1f3e1; 博客主页&#xff1a;点击 文章目录 介绍<plugins>标签解析拦截器链的工作原理插件的应用场景MyBatis插件应用的四个组件InterceptorChain和Interceptor MyBatis框架…...

[M最短路] lc743. 网络延迟时间(spfa最短路+单源最短路)

文章目录 1. 题目来源2. 题目解析 1. 题目来源 链接&#xff1a;743. 网络延迟时间 相关链接&#xff1a; [图最短路模板] 五大最短路常用模板) 2. 题目解析 怎么讲呢&#xff0c;挺抽象的…很久没写最短路算法了。反正也是写出来了&#xff0c;但脱离了模板&#xff0c;把…...

MySQL 中的锁

MySQL 中的锁&#xff1a;全面解析与应用指南 在 MySQL 数据库的复杂世界里&#xff0c;锁是确保数据一致性、完整性以及并发控制的关键机制。无论是简单的小型应用还是复杂的企业级系统&#xff0c;深入理解 MySQL 中的锁对于优化数据库性能、避免数据冲突和错误都具有至关重要…...

【动手学电机驱动】STM32-FOC(8)MCSDK Profiler 电机参数辨识

STM32-FOC&#xff08;1&#xff09;STM32 电机控制的软件开发环境 STM32-FOC&#xff08;2&#xff09;STM32 导入和创建项目 STM32-FOC&#xff08;3&#xff09;STM32 三路互补 PWM 输出 STM32-FOC&#xff08;4&#xff09;IHM03 电机控制套件介绍 STM32-FOC&#xff08;5&…...

【C++11】尽显锋芒

(续) 一、可变参数模板 C11支持可变参数模板&#xff0c;也就是说支持可变数量参数的函数模板和类模板&#xff0c;可变数目的参数被称 为参数包&#xff0c;存在两种参数包&#xff1a;模板参数包&#xff0c;表示零或多个模板参数&#xff1b;函数参数包&#xff1a;表示零…...

掌握控制流的艺术:Go语言中的if、for和switch语句

标题:掌握控制流的艺术:Go语言中的if、for和switch语句 在Go语言的编程世界中,控制流语句是构建程序逻辑的基石。if语句、for循环和switch语句是我们最常用的控制流工具,它们让我们能够根据不同的条件执行不同的代码块。本文将深入探讨这些语句的使用方法、技术细节和实际…...

飞书会话消息左右排列

飞书会话消息左右排列 1. 飞书登录后&#xff0c;点击头像&#xff0c;弹出菜单有个按钮设置 2. 3....

.net 支持跨平台(桌面)系列技术汇总

1. 首先微软老大哥的.net core 。 .NET Core 是微软开发的一个跨平台、高性能的开源框架&#xff0c;用于构建云和互联网连接的新型应用。 它允许开发者在 Windows、macOS 和 Linux 上使用喜爱的开发工具进行开发&#xff0c;并支持部署到云或本地环境。 .NET Core 是对 .NET …...

springboot 静态资源访问

最近在学习springboot&#xff0c;在学习中一个静态资源访问&#xff0c;难道了我三天&#xff0c;在网上找了很多的资料&#xff0c;又是配置&#xff0c;又是重写WebMvcConfigurationSupport&#xff0c;因为以前没有接触&#xff0c;本来很简单的事情走了很多弯路&#xff0…...

【linux学习指南】初识Linux进程信号与使用

文章目录 &#x1f4dd;信号快速认识&#x1f4f6;⽣活⻆度的信号&#x1f4f6; 技术应⽤⻆度的信号&#x1f309; 前台进程&#xff08;键盘&#xff09;&#x1f309;⼀个系统函数 &#x1f4f6;信号概念&#x1f4f6;查看信号 &#x1f320; 信号处理&#x1f309; 忽略此信…...

L1G1000 书生大模型全链路开源开放体系笔记

关卡任务 观看本关卡视频后&#xff0c;写一篇关于书生大模型全链路开源开放体系的笔记。 视频链接&#xff1a;【书生浦语大模型全链路开源体系】 : 书生浦语大模型开源开放体系_哔哩哔哩_bilibili 书生大模型全链路开源开放体系笔记 在人工智能领域&#xff0c;大模型的…...

亚信安全与飞书达成深度合作

近日&#xff0c;亚信安全联合飞书举办的“走近先进”系列活动正式走进亚信。活动以“安全护航信息化 共筑数字未来路”为主题&#xff0c;吸引了众多数字化转型前沿企业的近百位领导参会。作为“走近先进”系列的第二场活动&#xff0c;本场活动更加深入挖掘了数字化转型的基础…...

深入讲解Spring Boot和Spring Cloud,外加图书管理系统实战!

很抱歉&#xff0c;我的疏忽&#xff0c;说了这么久还没有给大家详细讲解过Spring Boot和Spring Cloud,那今天给大家详细讲解一下。 大家可以和下面这三篇博客一起看&#xff1a; 1、Spring Boot 和 Spring Cloud 微服务开发实践详解https://blog.csdn.net/speaking_me/artic…...

【三维生成】Edify 3D:可扩展的高质量的3D资产生成(英伟达)

标题&#xff1a;Edify 3D: Scalable High-Quality 3D Asset Generation 项目&#xff1a;https://research.nvidia.com/labs/dir/edify-3d demo&#xff1a;https://build.nvidia.com/Shutterstock/edify-3d 文章目录 摘要一、前言二、多视图扩散模型2.1.消融研究 三、重建模型…...

Java求职招聘网站开发实践

一、项目介绍 本文将介绍如何使用Java技术栈开发一个求职招聘网站。该网站主要实现求职者和招聘方的双向选择功能&#xff0c;包含用户管理、职位发布、简历投递等核心功能。 二、技术选型 后端框架&#xff1a;Spring Boot 2.7.0数据库&#xff1a;MySQL 8.0前端框架&#…...

一文详细了解websocket应用以及连接断开的解决方案

文章目录 websocketvite 热启动探索websocket -心跳websocket 事件监听应用过程中问题总结 websocket Websocket简介 定义和工作原理 Websocket是一种在单个TCP连接上进行全双工通信的协议。与传统的HTTP请求 - 响应模式不同&#xff0c;它允许服务器主动向客户端推送数据。例…...

如何做含有identify抓信号的fpga版本(image或者Bit)

在数字的FPGA debug中除了ila就是identify了&#xff0c;identify是synopsys公司的RTL级的调试工具。要用起来idetify&#xff0c;第一步就是要做出含有identify的信号的FPGA版本&#xff0c;quartus的是image&#xff0c;Ximlinx的是Bit或者Bin文件。具体有以下几步&#xff1…...

AIGC实践-使用Amazon Bedrock的SDXL模型进行文生图

一、Bedrock 简介 Amazon Bedrock 是 Amazon Web Services (AWS) 提供的一种生成式 AI 服务。通过 Bedrock&#xff0c;用户可以方便地使用多种基础模型&#xff08;Foundation Models&#xff09;&#xff0c;包括 OpenAI 的 GPT、Anthropic 的 Claude 等。这些模型可以用于各…...

【源码】Sharding-JDBC源码分析之SQL中分片键路由ShardingSQLRouter的原理

Sharding-JDBC系列 1、Sharding-JDBC分库分表的基本使用 2、Sharding-JDBC分库分表之SpringBoot分片策略 3、Sharding-JDBC分库分表之SpringBoot主从配置 4、SpringBoot集成Sharding-JDBC-5.3.0分库分表 5、SpringBoot集成Sharding-JDBC-5.3.0实现按月动态建表分表 6、【…...

初学 flutter 环境变量配置

一、jdk&#xff08;jdk11&#xff09; 1&#xff09;配置环境变量 新增&#xff1a;JAVA_HOMEC:\Program Files\Java\jdk-11 //你的jdk目录 在path新增&#xff1a;%JAVA_HOME%\bin2&#xff09;验证是否配置成功&#xff08;cmd运行命令&#xff09; java java -version …...