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

【团队开发】git 操作流程

1 创建仓库

创建仓库

得到一个URL

2 git操作

2.1 初始化

初始化仓库

git init 

添加origin地址

git remote add origin 远程仓库地址

修改origin地址

git remote set-url origin <new-url>

运行查看remote命令

git remote -v 
10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ git remote -v
origin  https://gitee.com/zhaojianfei0820/comfort_-engine.git (fetch)
origin  https://gitee.com/zhaojianfei0820/comfort_-engine.git (push)

2.2 协作开发

主分支创建文件并推送

10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ git add .10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ git commit -m "master add test&readme"
[master (root-commit) bdeda1a] master add test&readme2 files changed, 0 insertions(+), 0 deletions(-)create mode 100644 ReadMe.txtcreate mode 100644 Test/test.py10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ git push origin master
10Enumerating objects: 4, done.
Counting objects: 100% (4/4), done.
Delta compression using up to 16 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (4/4), 292 bytes | 292.00 KiB/s, done.
Total 4 (delta 0), reused 0 (delta 0), pack-reused 0
remote: Powered by GITEE.COM [GNK-6.4]
To https://gitee.com/zhaojianfei0820/comfort_-engine.git* [new branch]      master -> master

创建新的开发分支

git branch <new branch name>

创建新分支并切换到该分支

git checkout -b <new branch name>

查看所有的分支

git branch

将本地创建的分支推送到远程分支

git push origin <branch name>

在当前分支创建一个新的分支后,新创建的分支会复制当前分支的所有代码

2.3 邀请同事协作开发

可以在gitee中发送邀请。

协同开发

创建三个分支,分别是:

  • master
  • feature/zhao
  • feature/x

master分支做为主分支,feature/zhao开发功能A,feature/x开发功能B

开发者A 在feature/zhao上面开发

git add.

git commit -m “”

git push origin feature/zhao

开发者B在feature/x上面开发

git add .

git commit -m “”

git push origin feature/x

master合并代码

切换到master分支

git checkout master 

合并feature/zhao分支的代码

git merge feature/zhao

合并feature/x分支的代码

git merge feature/x

2.4 merge操作的常见问题

在master分支创建一个bug.txt文件

10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ touch bug.txt10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ vim bug.txt

bug.txt文件是:

10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ cat bug.txt
第一行:bug file 2023-12-05
第二行:bug file 2023-12-05

基于master分支创建一个hotfix分支,用于bug修复

git checkout -b hotfix

在hotfix分支修改bug.txt文件

10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (hotfix)
$ vim bug.txt10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (hotfix)
$ cat bug.txt
bug file 2023-12-05
bug file 2023-12-12
success

开始合并分支

合并之前先返回master

git checkout master

触发合并

git merge hotfix
10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master)
$ git merge fixhot2
CONFLICT (modify/delete): bug.txt deleted in HEAD and modified in fixhot2.  Version fixhot2 of bug.txt left in tree.
Automatic merge failed; fix conflicts and then commit the result.10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master|MERGING)
$

直接编辑文件

10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master|MERGING)
$ git status
On branch master
You have unmerged paths.(fix conflicts and run "git commit")(use "git merge --abort" to abort the merge)Unmerged paths:(use "git add/rm <file>..." as appropriate to mark resolution)deleted by us:   bug.txtno changes added to commit (use "git add" and/or "git commit -a")

编辑器直接处理冲突

10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master|MERGING)
$ git add .10321@coderzhao MINGW64 /e/Siemens_projects/code/comfort_engine (master|MERGING)
$ git commit -am"hebingyixia"
[master 1365cd4] hebingyixia

处理之后提交

git push origin master 

其他用户拉取代码

git pull origin <other-branch>

拉取分支时候,自己分支的内容不会被覆盖。

http://www.lqws.cn/news/590779.html

相关文章:

  • Electron 沙箱模式深度解析:构建更安全的桌面应用
  • c++学习(八、函数指针和线程)
  • idea maven自动导包 自动清除无用的依赖包
  • 怎么查看Android设备中安装的某个apk包名和启动页activity
  • 设计模式-模板模式
  • Linux驱动学习day12(mmap)
  • 道可云人工智能每日资讯|浦东启动人工智能创新应用竞赛
  • 业界优秀的零信任安全管理系统产品介绍
  • 从0开始学习R语言--Day35--核密度动态估计
  • ABB PPD 113 B03-23-100110 3 bhe 023584 r 2334 AC 800 pec控制系统
  • 腾讯 iOA 零信任产品:安全远程访问的革新者
  • ASP.NET代码审计 MVC架构 SQL注入漏洞
  • LINUX2.6设备注册与GPIO相关的API
  • 将N8N配置为服务【ubuntu】
  • 第4课:Flask请求与响应对象深度解析
  • 使用mavros启动多机SITL仿真
  • WPF学习笔记(17)样式Style
  • Coze(扣子):基础学习
  • 利用视觉-语言模型搭建机器人灵巧操作的支架
  • 【Docker基础】Docker数据卷:数据卷的作用与使用场景
  • 算法-每日一题(DAY12)最长和谐子序列
  • Salesforce Accountアクションボタン実装ガイド
  • 简单聊聊 Flutter 在鸿蒙上为什么可以 hotload ?
  • 飞算JavaAI—AI编程助手 | 编程领域的‘高科技指南针’,精准导航开发!
  • 具身多模态大模型在感知与交互方面的综述
  • sqlmap学习ing(2.[第一章 web入门]SQL注入-2(报错,时间,布尔))
  • rocketmq 之 阿里云转本地部署实践总结
  • Vue3 中 Excel 导出的性能优化与实战指南
  • 创建和连接Vue应用程序实例
  • 缓存系统-淘汰策略