git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支

2023-12-15 17:45

本文主要是介绍git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

GIT | 分支

文章目录

  • GIT | 分支
    • 创建分支
    • 合并分支
    • 删除分支
    • 合并冲突
    • 分支管理策略
    • bug分支
    • 强制删除分支

创建分支

查看当前本地仓库中有哪些分支

git branch

HEAD所指向的分支就是当前正在工作的分支

cat .git/HEAD

在这里插入图片描述

创建一个分支

git branch dev

创建好了,但是目前还是指向master

在这里插入图片描述
用tree命令也可以看到已经创建分支成功了

在这里插入图片描述

创建出来的分支,和主分支的最新记录是一样的

在这里插入图片描述

切换分支就是让HEAD指向我们的dev分支

git checkout dev

在这里插入图片描述

我们在dev分支上堆ReadMe文件进行了修改

在这里插入图片描述

再进行提交

在这里插入图片描述

这个时候再切换回master分支
查看文件

在这里插入图片描述

可以看到刚刚新加的那行文件不见了~~

那我们再切换回dev分支上看

在这里插入图片描述
发现那行新加的还在

我们查看这里发现已经变了
在这里插入图片描述

我们查看记录
dev上是最新的记录,master分支第二

在这里插入图片描述

我们最终的效果是在master分支上看到我们的效果,我们怎么操作呢?

合并分支

这就要我们合并分支,在合并分支之前就需要先切换到我们master分支上

git merge dev

在这里插入图片描述

删除分支

只能在其他的分支上删除本分支

git branch -d dev

在这里插入图片描述

合并冲突

在合并分支的时候,我们在master分支上已经修改了文件,而我在dev分支上也修改了文件,然后合并的时候就会出现报错,我们来演示一下

快速创建分支并且进入分支

git checkout -b dev1

在这里插入图片描述

我们将原来的aaa改成了bbb

在这里插入图片描述

然后提交上去

在这里插入图片描述

我们切换到master分支上查看一下文件内容,发现还是aaa,因为还没有合并

在这里插入图片描述
在这里插入图片描述

接下来我们就继续将这个aaa改成ccc,然后再进行合并分支

在这里插入图片描述

在这里插入图片描述
这个时候再进行合并,会提示合并冲突

git merge dev1

在这里插入图片描述

我们打开ReadMe文件查看一下

在这里插入图片描述

这个时候就要手动选择要保留哪些代码

假设我们就保留这些代码

在这里插入图片描述

然后再进行提交

在这里插入图片描述
查看是否是最新提交

在这里插入图片描述

可视化的查看方法

git log --graph --abbrev-commit

在这里插入图片描述

分支管理策略

不使用Fast forward模式

创建一个新分支

git checkout -b dev2

在这里插入图片描述

修改ReadMe文件,并提交

在这里插入图片描述

在这里插入图片描述

切换回master分支后进行合并

不使用Fast forward模式

git merge --no-ff -m "merge with no-ff" dev2

在这里插入图片描述

bug分支

假如我们现在正在 dev2 分支上进行开发,开发到一半,突然发现master 分支上面有 bug,需要
解决。在Git中,每个 bug 都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除

在这里插入图片描述

  • 这个时候主分支出现了一个bug,这个时候就要i切换到master分支

在这里插入图片描述

那我们不想这样,我们可以这样做

将工作区的内容进行保存

git stash

在这里插入图片描述

修复完bug后,我们就需要进行重新回到dev2分支继续开发

git stash pop

在这里插入图片描述
现在我们到了dev2分支上了,我们继续开发

在这里插入图片描述
然后提交,在dev分支上进行了新的提交

在这里插入图片描述

这个时候就需要合并了,但是合并的时候就会出现冲突,刚刚master修改了bug了,这次又要进行合并分支,我们需要解决错误

我们需要不在master上合并分支,在dev合并master主分支,把问题再本地上解决了再做下一步

我们在dev2分支上进行合并
在这里插入图片描述

手动修改冲突
在这里插入图片描述

然后就可以合并了~~

在这里插入图片描述

最后不要忘了,把刚刚的临时分支和开发分支删除~~

在这里插入图片描述

强制删除分支

如果在开发中如果在一个分支上已经开发,对代码进行提交了,这个时候用传统的方法进行删除是不能删除的,我们需要用到-D来进行删除~~

git branch -D dev3
  • 分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。
  • 现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的支上,这样,既安全,又不影响别人工作。
  • 并且 Git 无论创建、切换和删除分支,Git在1秒钟之内就能完成!无论你的版本库是1个文件还是1万个文件。

这篇关于git的分支的使用,创建分支,合并分支,删除分支,合并冲突,分支管理策略,bug分支,强制删除分支的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/497316

相关文章

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@