0007-Git不完全操作指南之本地操作3——merge

概念

我们现在已经了解了分支的概念,也知道了要如何新建分支了。当我们在开发新功能时,通常会先创建一个新分支,在这个新分支的基础上开发,当功能开发并测试完毕,准备上线时,就需要将这个分支合并会主分支,让主分支包含所有的变更。那么,我们要如何合并分支呢?今天我们要学习的merge就是合并分支的其中一种方式。

merge命令在 Git 中合并两个分支时会产生一个特殊的提交记录,它有两个父节点。翻译成自然语言相当于:"我要把这两个父节点本身及它们所有的祖先都包含进来。"

图示

我们准备了两个分支,每个分支上各有一个独有的提交。这意味着没有一个分支包含了我们修改的所有内容。咱们通过合并这两个分支来解决这个问题。

如下图,我们要把 bugFix 合并到 main 里。

执行以下命令:

bash 复制代码
git merge bugFix

从上图我们可以发现,我们在执行了merge命令后,产生了一条新的提交记录C4,并且我们main分支的指针指向了该提交记录,我们在讲分支时说过,分支其实就是简单的一个指向某个提交的指针,当main分支指向了C4提交之后,因为C4提交已经包含了我们这个仓库中所有的提交了,也就意味着main分支已经包含了所有的提交了。

如果此时我们想让bugFix分支也合并一下main分支,让bugFix分支也包含所有变更要怎么操作呢?

bash 复制代码
git checkout bugFix
git merge main

此时由于main分支本身就包含了所有提交,因此只需要将bugFix的指针直接指向C4提交,即main所指向的提交记录即可。

从上面的图示中,我们也可以看到,merge操作也有一个弊端,就是会产生一条新的提交记录C4,并且产生了一条分叉。这条记录是一个合并历史。即我们实际上更改了git的提交线,在里面增加了一条提交记录。那么,有没有一种方法,能让我们不产生新的提交记录就能够让目标分支包含所有变更,让我们的主分支的提交记录看起来足够清爽呢?答案是有的。我们可以用rebase实现,这个我们下一节再详说,不然就喧宾夺主了。

常用命令

bash 复制代码
# 将目标分支合并到当前分支
git merge bugFix

# 将合并过来的分支的所有提交记录合并成一条
git merge --squash bugFix

# 执行上述命令后,无论你再bugFix分支上有多少条当前分支上没有的提交记录,在合并时,都会
# 合并成一条,这样,我们当前分支就不会包含一堆bugFix分支的中间临时提交记录,只会有一个
# 最终的提交记录,看起来会干爽很多

# 显示执行合并时产生的新的提交记录的提交信息。
git merge -e "merge: bugFix into main"

# 如果在合并过程中发生了冲突,那么有以下两种处理方式
# 1. 不想继续合并了,想要终止合并
git merge --abort
# 2. 已经解决了冲突了,继续合并
git merge --continue
相关推荐
韭菜炒大葱8 小时前
Git入门指南:掌握版本控制的核心工作流程
git·面试
用户6600676685399 小时前
Git 入门指南:掌握版本控制的核心概念与命令
git
小生不才yz10 小时前
(一)仓库创建与配置 - .git 目录的结构与作用
git
三坛海会大神55511 小时前
CICD(一)CI/CD概述及GitLab部署和一些Git命令
git·ci/cd·1024程序员节
荣光波比18 小时前
CICD(一)—— 从零搭建 GitLab 全流程(Docker 部署 + 实战指南)
git·ci/cd
摇滚侠1 天前
VScode 提交代码 Git
git
YuforiaCode1 天前
移除原有 Git 仓库关联,在IDEA中重新初始化 Git 并推送到新仓库(详细图解、包含相关问题的解决办法)
git
UIUV1 天前
Git程序员入门笔记:从零开始掌握分布式版本控制
git
星光不问赶路人1 天前
彻底清理 Git 分支:从查看到批量删除无效分支的全流程指南
git·github
如果是君2 天前
【git使用】ubuntu下利用git工具提交一个工程
linux·git·ubuntu