【随笔】Git 高级篇 -- 管理多分支 git rebase(二十二)

  • 💌 所属专栏:【Git】

  • 😀 作  者:我是夜阑的狗🐶

  • 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询!

  • 💖 欢迎大家:这里是CSDN,我总结知识的地方,喜欢的话请三连,有问题请私信 😘 😘 😘

您的点赞、关注、收藏、评论,是对我最大的激励和支持!!!🤩 🤩 🤩

文章目录


前言

大家好,又见面了,我是夜阑的狗🐶,本文是专栏【Git】专栏的第二十二篇文章;

这是今天学习到Git 高级篇 -- 管理多分支 💖💖💖,开启新的征程,记录最美好的时刻🎉,每天进步一点点。

专栏地址:【Git】 , 此专栏是我是夜阑的狗对Git,Gitee等工具使用过程的总结,希望能够加深自己的印象,以及帮助到其他的小伙伴😉😉。

如果文章有什么需要改进的地方还请大佬不吝赐教👏👏。


一、管理多分支

这里给大家推荐一个好用的 Git在线练习地址。在这练习网站里面也有自己的教程,就让我们一步一步跟着教程学习吧,记录下自己的所感所悟。前面已经简单的学习了查询当前分支里最近标签的距离,接下来就让我们看看在实际项目过程中是怎么管理合并多分支的吧。话不多说,让我们原文再续,书接上回吧。

1、介绍

在实际项目过程中可能会出现了很多分支呢!接下来就让我们把所有这些分支上所做的工作都通过 rebase 合并到 main 分支上吧。

但是这时候你的领导可能就会给你提了点要求 ------ 他们希望得到有序的提交历史,也就是我们最终的结果应该是 C6' 在 C7' 上面, C5' 在 C6' 上面,依此类推。

2、示范

git rebase 指令用于将一个分支的提交逐个应用到另一个分支上,以使得提交历史更加整洁。以下是该指令的基本用法:

  • 单参数
python 复制代码
git rebase <branch>

其中 <branch> 参数是要将当前分支的提交应用到的目标分支。执行该指令后,Git会将当前分支的各个提交逐个应用到目标分支上,创建新的提交。这样,目标分支就会包含当前分支的最新更改,而且提交历史线会更加整洁地呈现出一条直线。

  • 双参数
python 复制代码
git rebase <branch1> <branch2>

其中 <branch1> 参数是要将当前分支的提交应用到的目标分支,<branch2> 参数是需要提交到目标分支的源分支。

需要注意的是,git rebase 不会保留原始分支上的提交。相反,它会将提交逐个应用到目标分支上,并创建新的提交。如果在 git rebase 的过程中发生冲突,需要手动解决冲突并使用 git add 命令将解决后的更改添加到暂存区。然后,使用 git rebase --continue 指令继续进行 git rebase 的操作。

即使你搞砸了也没关系,用 reset 命令就可以重新开始了。记得看看作者提供的答案,看你能否使用更少的命令来完成任务!

3、实战

从前面了解到具体的实现的步骤,就可以开始实战啦。这里先给大家说一下这个练习网站的一些使用技巧,

  • help 指令

执行这个命令后就会有个帮助信息的弹窗。

  • levels 指令

执行完这个命令之后就能看到关卡目录了。

  • 目标
  • 开始结构
  • Step 1、合入 bugFix 分支

bugFix 分支合入到 main 分支下;

python 复制代码
git rebase main bugFix

运行结果如下图所示:

  • Step 2、合入 side 分支

side 分支合入到 bugFix 分支下;

python 复制代码
git rebase bugFix side

运行结果如下图所示:

  • Step 3、合入 another 分支

another 分支合入到 side 分支下;

python 复制代码
git rebase side another

运行结果如下图所示:

  • Step 4、更新 main 分支

最后在把 main 分支更新值 another 分支即可;

python 复制代码
git rebase another main

运行结果如下图所示:

达成目标之后就会有成功的提示。


总结

**  感谢观看,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹 🌹 🌹**

**  也欢迎你,关注我。👍 👍 👍**

**  原创不易,还希望各位大佬支持一下,你们的点赞、收藏和留言对我真的很重要!!!💕 💕 💕 最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!下期再见。🎉**

更多专栏订阅:

订阅更多,你们将会看到更多的优质内容!!

相关推荐
刘婉晴6 小时前
【信息安全工程师备考笔记】第三章 密码学基本理论
笔记·安全·密码学
晓数8 小时前
【硬核干货】JetBrains AI Assistant 干货笔记
人工智能·笔记·jetbrains·ai assistant
我的golang之路果然有问题9 小时前
速成GO访问sql,个人笔记
经验分享·笔记·后端·sql·golang·go·database
lwewan9 小时前
26考研——存储系统(3)
c语言·笔记·考研
jstart千语9 小时前
【Git】连接github时的疑难杂症(DNS解析失败)
git·github
搞机小能手9 小时前
六个能够白嫖学习资料的网站
笔记·学习·分类
工具罗某人10 小时前
TortoiseGit使用图解
git
Zhuai-行淮10 小时前
vscode和git 踩坑
ide·git·vscode
nongcunqq10 小时前
爬虫练习 js 逆向
笔记·爬虫
汐汐咯10 小时前
终端运行java出现???
笔记