Git 分支操作全解析:创建、切换、合并、删除及冲突解决

news2024/9/22 1:50:29

        “ 在现代软件开发中,高效的版本控制是确保项目成功的关键。Git 提供了强大的分支管理功能,使得开发者能够独立地进行功能开发、修复 bug 和进行紧急修补。本文将深入探讨 Git 分支的基本操作,包括创建、切换、合并和删除分支,同时重点关注如何解决常见的冲突问题。掌握这些技巧不仅能提升开发效率,还能优化团队协作。让我们一起来揭开 Git 分支管理的神秘面纱,提升项目的管理水平。

01分支简介 

        管理代码的时候,在集中式管理(比如SVN)中会创建Trunk、Branches、Tag等一些目录,分别放置开发代码、代码分支以及代码的里程碑。那么在 Git 中也使用分支和tag来管理代码。分支就是就是一个代码的副本,可以基于分支进行独立开发。比如我们创建 Bug 分支或者 Feature 分支,等开发好了再合并到主干上。使用 Git 可以非常方便灵活地管理分支和基于分支工作:

git branch   # 查看分支
git branch develop  # 创建develop分支
git checkout –b feature/FT-123456  # 创建FT-123456的一个feature分支
git checkout develop   # 切换分支
git merge feature/FT-123456   # 合并分支
git branch –d feature/FT-123456   # 删除FT-123456的feature分支
git push –u origin hotfix/ISSUE-345678    # 推送分支

版本管理的标准流程:

  • Master :稳定压倒一切,禁止尚 review 和测试过的代码提交到这个分支上,Master上的代码是可以随时部署到线上生产环境的。

  • Develop :开发分支,我们的持续集成工作在这里,code review过的代码合入到这里,我们以下要讲的BUG fix和feature开发都可以基于develop分支拉取,修改完之后合入到develop分支。

  • Feature :功能开发和change request的分支,也即我们每一个feature都可以从devlop上拉取一个分支,开发、review和测试完之后合入develop分支。

  • Hotfix :紧急修改的分支,在master发布到线上出现某个问题的时候,算作一个紧急布丁。从master分支上拉取代码,修改完之后合入develop和master分支。

  • Release :预发布分支,比如0.1、0.2、1.12版本,我们一般说的系统测试就是基于这些分支做的,如果出现bug,则可以基于该release分支拉取一个临时bug分支。

  • Bug :bug fix的分支,当我们定位、解决后合入develop和Release分支,然后让测试人员回归测试,回归测试后由close这个bug。

02查看分支 

        首先要知道怎么去查看分支,使用git branch命令,这个命令只打印本地仓库的分支;如果想把远端的分支也查看一番,可以使用git branch -a命令。其中其星号*表示当前在哪个分支。示例:

 

fly@LAPTOP-V34UPA81:~/workspace/fly-mem-test$ git branch
* master
fly@LAPTOP-V34UPA81:~/workspace/fly-mem-test$ git branch -a
* master
  remotes/origin/HEAD -> origin/master
  remotes/origin/master
fly@LAPTOP-V34UPA81:~/workspace/fly-mem-test$

03创建、切换分支

创建分支有两种方式:

git branch 分支名
git checkout -b 分支名

它们的不同:

  • git branch 分支名虽然创建了分支,但不会自动切换到新建的分支;而且是在本地创建的分支,远端没有这个分支。

  • git checkout -b也会创建分支,而且会自动切换到新的分支上。

  • 切换分支也有两种方式:

    git checkout 分支名
    git switch 分支名
    

    git check命令的功能很多,除了切换分支,还可以做版本回退等操作,因此,后来 Git 又增加了一个git switch命令。

    git checkout -b可以理解为两个命令的结合,即 创建分支 + 切换分支两个操作合成一个命令。

    04合并分支 (重点)

合并分支有两个命令:

  • git merge

  • git rebase,不推荐使用。git rebase不仅可以合并提交,还可以合并分支。

合并分支的主要作用:通常,在实际项目开发过程中,会有多个分支,而且都是基于某个主分支进行开发。最终,所有的分支实现的功能都要合并到主分支,所有人都可以看到项目的修改。我们要把自己分支的修改应用到主分支,就需要合并分支。

 

git merge合并 Git 分支的步骤:

  1. 切换到目标分支:这是你希望将更改合并到的分支。例如,如果你想将 feature-branch 合并到 main,需要首先切换到 main 分支,拉取该分支的最新代码。

    git checkout main
    git pull
    
  2. 合并分支:使用 git merge 命令将另一个分支合并到当前分支。例如,将 feature-branch 合并到 main:

    git merge feature-branch
    
  3. 处理冲突(如果有):如果存在冲突,Git 会提示你解决冲突。你需要手动编辑冲突的文件,然后添加更改并完成合并。

# 编辑冲突文件
vim 冲突的文件
# 解决冲突后,添加已解决的文件
git add <file-with-conflict>

# 完成合并
git commit . -i -m "merge fix conflicts."

冲突文件示例:

  1. 测试代码并推送更改(如果需要):将合并后的更改推送到远程仓库。

    git push origin main
    

git rebase合并分支(不推荐使用)
使用 git rebase 进行分支合并的步骤如下:

  1. 切换到需要更新的分支:假设要将 feature-branch 的更改应用到 main 分支上,首先需要切换到 feature-branch。

    git checkout feature-branch
    
  2. 执行 rebase 操作:将 feature-branch 的更改应用到 main 分支上。

    git rebase main
    

    这会将 feature-branch 上的提交“移到” main 分支的顶部。feature-branch 上的更改将会被逐个应用到 main 上的最新提交之后。

  3. 解决冲突(如果有):如果在 rebase 过程中出现冲突,Git 会提示解决冲突。解决冲突后,继续 rebase 操作。注意,git rebase解决完冲突后并不会增加一次提交。

 

# 编辑冲突文件
vim 冲突的文件
# 解决冲突后,添加已解决的文件
git add <file-with-conflict>

# 继续 rebase
git rebase --continue

  1. 推送更改(如果需要):由于 rebase 操作会改变提交历史,如果已经将 feature-branch 推送到远程仓库,需要强制推送更新。

    git push --force origin feature-branch
    

    注意:强制推送会覆盖远程仓库中的 feature-branch,在共享仓库中使用时请小心。

不推荐使用git rebase的原因:虽然git rebase让提交记录非常整洁,它整体上比git merge上一个提交记录,但是它会让人造成混淆(时间线错乱),无法辨别真正的版本依赖关系。

git merge更加符合实际开发的时间线。

 什么时候使用git rebase ?
依据是:是否有其他人依赖我当前rebase的这个分支。如果有依赖,则应当采用git merge进行合并,否则可以 使用git rebase 命令。因为git rebase会改变提交日志(即 commit id),如果有人依赖我的分支,就可能出现异常。

git rebase原理:从两个分支的共同祖先开始提取当前分支上的修改,提取的提交应用到目标分支的最新提交的后面,将当前分支指向目标分支的最新提交,可能引发其他人基底发生改变。

05删除分支 

删除本地分支:

  1. 切换到其他分支:在删除分支之前,确保不在要删除的分支上。例如,如果要删除 feature-branch,可以切换到 main 或其他分支。

    git checkout main
    
  2. 删除本地分支:使用 -d 选项删除本地分支,如果分支上有未合并的更改,Git 会警告你。

    git branch -d feature-branch
    

    如果你确定要删除分支,即使它有未合并的更改,可以使用 -D(强制删除):

    git branch -D feature-branch
    

删除远程分支:使用 git push 命令并指定 --delete 选项来删除远程分支。例如,删除远程 feature-branch

git push origin --delete feature-branch
# or
git push origin -d feature-branch

06解决冲突  

        冲突产生原因:不同分支修改了同一文件的同一行或者相邻行。
        解决原则:不要影响其他人提交的功能,也不能破坏自己提交的功能。也可以跟其他人协商解决。
建议:提交前先pull更新最新代码。

 

git mergegit rebase解决冲突的不同:

  • git merge先解决冲突文件,然后使用git add,最后git commit . -i -m "....",完成。

  • git rebase先解决冲突文件,然后使用git add.标记解决,最后git rebase --continue,完成。

 

07总结 

        在软件开发过程中,Git 的分支管理是实现高效协作和版本控制的核心工具。通过本文的介绍,深入探讨了 Git 分支的创建、切换、合并、删除及冲突解决等操作,帮助开发者掌握了以下几点关键内容:

  1. 分支管理的基本概念:Git 的分支机制允许我们在独立的环境中进行开发和测试,确保主分支的稳定性。理解分支的作用(如 FeatureBugHotfix 和 Release)对有效管理项目至关重要。

  2. 创建和切换分支:使用 git branch 和 git checkout -b 创建和切换分支,使得开发者能够灵活地在不同功能或修复任务之间切换,提高了开发的灵活性和组织性。

  3. 合并分支的技巧:合并分支是将开发成果整合到主干的关键步骤。通过 git merge 和 git rebase,可以将功能分支的更改引入到主分支中。选择合适的合并策略对于避免冲突和保持提交历史的清晰至关重要。

  4. 处理冲突:冲突是分支管理中常见的问题。通过 git merge 和 git rebase 提供的工具和方法,可以有效地解决冲突,确保代码库的稳定性。理解冲突产生的原因和解决原则能够帮助团队更高效地协作。

  5. 删除分支:分支的删除操作(包括本地和远程)有助于保持项目的整洁。了解如何安全地删除不再需要的分支,可以避免混乱和不必要的分支堆积。

 

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

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

相关文章

使命同心,六西格玛同行,顶尖人才扎堆来!——张驰咨询

在当今竞争激烈的商业环境中&#xff0c;顶尖人才不仅是企业创新与突破的源泉&#xff0c;更是决定企业成败的关键因素。如何有效吸引并长期留住这些宝贵资源&#xff0c;成为企业家们亟待解决的难题。企业文化、领导风格以及先进的管理方法&#xff0c;如六西格玛&#xff0c;…

两个视频如何合成一个视频?推荐8个视频合并方法

两个视频如何合成一个视频&#xff1f;在数字时代&#xff0c;视频内容的创作和编辑变得越来越普及。无论是在个人项目还是专业制作中&#xff0c;将两个视频合并成一个已成为常见需求。这一操作不仅能提高视频内容的连贯性&#xff0c;还能增强观众的观看体验。下面&#xff0…

大模型火了一年半,AI应用如何实现商业变现?

自ChatGPT走红后&#xff0c;国内AI大模型建设潮起&#xff0c;如今经过一年半的快速发展后&#xff0c;大模型商业化显著提速。自生成式AI席卷各行业以来&#xff0c;市场对AI应用发展的预期高涨&#xff0c;但AI应用似乎陷入“增长难题”&#xff0c;进展不及预期&#xff0c…

Java筑基之路:数组的深入了解学习!

&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d; &#x1f947;博主昵称&#xff1a;小菜元 &#x1f35f;博客主页…

科技温柔拥抱梦乡!康姿百德柔压磁性枕舒适与科技的甜蜜邂逅

解锁未来睡眠新姿势&#xff01;康姿百德柔压磁性枕&#xff0c;科技护航每一夜好梦 在现代家居产品的设计中&#xff0c;科技与舒适性的结合越来越受到人们的关注。康姿百德柔压磁性枕正是一款将科技与舒适结合的产品&#xff0c;为现代生活注入了新的活力。 康姿百德柔压磁性…

【发邮件】 在邮件中添加 (mailto:) 链接的返回电子邮件

&#x1f433;打工人给导师发邮件&#xff0c;注意格式中学到的一个东西&#xff0c;记录一下 发送邮件想达到点击这个邮件就能到收件人的位置&#xff0c;不用跳转。 也就是你点击这个邮件 就能直接给你蹦到发送这个人&#xff0c;然后直接发送 只需要在邮件那个位置 加入超…

语言大模型的分布式训练与高效微调指南

最近语言大模型&#xff08;LLM&#xff09;异常火爆&#xff0c;一个非常特别的开源社区正在探索在消费级硬件上微调、提供服务和进行推理的最佳方式。为满足上述需求&#xff0c;出现了许多出色的开源代码库&#xff0c;以HuggingFace生态系统为中心&#xff0c;这些代码库还…

【干货】看看我司消息队列用啥,全网最接地气pulsar教程(含业务解耦demo源码)

前言 &#x1f34a;缘由 消息队列一出手&#xff0c;pulsar就知有没有 &#x1f423;闪亮主角 大家好&#xff0c;我是JavaDog程序狗 今天跟大家分享pulsar&#xff0c;一个分布式的消息发布/订阅传递平台。 本狗以身入局&#xff0c;将pulsar的使用场景&#xff0c;结合实…

【flask框架搭建服务器demo】Python 使用轻量级 Flask 框架搭建 Web 服务器可视化数据库数据demo

本文适合刚入门flask框架用来熟悉项目的开发人员&#xff0c;关于flask框架的组成概念一些用法请参考下面的文章 https://blog.csdn.net/qq_47452807/article/details/122289200 本文主要给出一个可视化sqlite数据库数据的demo&#xff0c;先展示一下效果&#xff1a; 主要的…

前端速通面经八股系列(二)—— HTML篇

HTML高频面经八股目录 1. src和href的区别2. 对HTML语义化的理解3. DOCTYPE(⽂档类型) 的作⽤4. script标签中defer和async的区别5. 常⽤的meta标签有哪些6. HTML5有哪些更新1. 语义化标签2. 媒体标签3. 表单4. 进度条、度量器5.DOM查询操作6. Web存储7. 其他 7. img的srcset属…

Python 图像处理进阶:特征提取与图像分类

特征提取 特征提取是计算机视觉中的一个重要环节&#xff0c;它可以从图像中提取出有助于后续处理的特征&#xff0c;比如用于识别和分类的关键点、纹理等。常见的特征提取方法包括SIFT、SURF和ORB等。 SIFT&#xff08;尺度不变特征变换&#xff09; SIFT是一种用于检测图像…

Web-ssrfme--redis 未授权访问攻击

目录 1、题目源码 2、测试ssrf 3、发现主机 4、发现服务 5、redis 未授权访问攻击 6&#xff0c;拿flag 1、题目源码 <?php highlight_file(__file__); function curl($url){ $ch curl_init();curl_setopt($ch, CURLOPT_URL, $url);curl_setopt($ch, CURLOPT_HEADER…

用Maven开发Spring Boot 项目

一、初识 Spring Boot Spring Boot框架是一 套开源的后台开发框架&#xff0c; 继承了Spring MVC框架的前辈SSM框架的优秀特性&#xff0c;通过注解大幅减少程序员写配置的工作量。从企业开发角度来看&#xff0c;它提供了自动化配置&#xff0c;内嵌容器和兼容Maven等核心功…

银河麒麟桌面操作系统V10:如何快速将应用固定到任务栏?

银河麒麟桌面操作系统V10&#xff1a;如何快速将应用固定到任务栏&#xff1f; 1、图形界面方法2、命令行方法2.1 固定应用2.2 取消固定 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在银河麒麟V10中&#xff0c;/usr/share/applications…

Vue 绘制圆形 上下左右

效果图 代码&#xff1a; <div style"transform: rotate(45deg)"><div id"top"><div id"top-left" click"addformData(true, form.lat, 0.000003, lat)"><ArrowUpBold style"height: 25px; width: 25px; tr…

winform 实现优美的进度条 包含百分比

winform 原生控件中包含进度条控件 ProgressBar。 但这个控件并没有告诉我们如何在上面实现 显示百分比进度的方式&#xff0c;或者说根本就不支持。但没 有百分比显示的进度条是没有灵魂的&#xff0c;可能是有点让人一头雾水的。 还好我们可以通过实现 ProgressBar 的 OnP…

海康VisionMaster使用学习笔记18-常见问题排查

常见问题排查思路 常见问题排查方法-安装阶段 常见问题排查方法-启动阶段 常见问题排查方法-使用阶段 常见问题排查方法-相关资料

outlook在“对我发送的邮件应用规则”时只能移动邮件副本的问题和解决方案

outlook在“对我发送的邮件应用规则时”只能移动邮件副本的问题 问题描述问题的解决方案第一步第二步 其他说明参考 问题描述 如果我们想对自己发送的邮件进行分类&#xff0c;可以使用规则将已发送的邮件移动到指定文件夹中&#xff0c;但是。当操作对象为“自己发送的邮件时…

运维学习————LVS集群和Keepalived+LVS高可用

目录 官网&#xff1a;LVS中文官网 一、概念 二、组成及软件工作层次图 ​编辑 三、整体架构 四、名词解释 五、三种工作模式 1、LVS-NAT 2、LVS-TUN 3、LVS-DR 六、DR模式的实现 1、克隆出LVS&#xff0c;配置虚拟IP 2、配置Nginx的虚拟IP Nginx1的配置 Nginx2…