图解Git——分支的新建与合并《Pro Git》

简介: 在Git开发中,新建与合并分支是常见的操作。以实际开发为例:为实现新需求创建分支`iss53`进行开发;遇紧急Bug时,切换至线上分支创建`hotfix`修复并合并回线上分支,再切换回`iss53`继续工作。完成`iss53`后,切换到`master`合并。若出现冲突,使用`git status`查看,手动编辑解决冲突后标记为已解决并提交。图形化工具如`git mergetool`也可辅助解决冲突。

⭐分支的新建与合并

先引入一个实际开发的工作流:

  1. 开发某个网站。
  2. 为实现某个新的需求,创建一个分支。
  3. 在这个分支上开展工作。

正在此时,你突然接到一个电话说有个很严重的问题需要紧急修补。你将按照如下方式来处理:

  1. 切换到你的线上分支(production branch)。
  2. 为这个紧急任务新建一个分支,并在其中修复它。
  3. 在测试通过之后,切换到线上分支,然后合并这个修补分支,最后改动推送到线上分支。
  4. 切换回你最初工作的分支,继续工作。

1. 新建分支

  1. 首先,模拟你正在你的项目上工作,并且在 master分支上已经有了一些提交:
    1. 提交历史图:

      编辑

  1. 现在,你将解决项目中 #53 问题,需要创建一个分支并切换到该分支:git checkout -b iss53——(创建分支git branch iss53切换分支git checkout iss53 的简写):
    1. 创建并切换后:

      编辑

  1. 在新创建的分支上工作并做提交后:git commit -a -m 'added a new footer [issue 53]'
    1. 提交 iss53 后:

      编辑

  1. 需要紧急修复 BUG(hotfix)时:
    1. 检查工作目录暂存区是否还存在未提交的修改:git status

    2. 切换回 master分支:git checkout master

    3. 建立 hotfix分支:git checkout -b hotfix

    4. 修复 Bug 后提交:git commit -a -m 'fixed the Bug'

    5. 提交后:

      编辑

  1. 将修改后的 hotfix 分支合并到 master 分支:
    1. git checkout master:切换回 master 分支。

    2. git merge hotfix:合并 hotfix 分支。

    3. 这时会出现 Fast-forward: 在合并时,如果一个分支是另一个分支的直接后继,Git 会将指针直接向前推进,无需解决冲突,这种合并叫做“快进(fast-forward)”。

    4. 合并后,master 被快进到 hotfix

      编辑

    5. 删除 hotfixgit branch -d hotfix

    6. 切换回工作分支— iss53分支:git checkout iss53

    7. 完成 iss53 工作后提交:git commit -a -m 'finished the new footer [issue53]'

      1. 提交 issue53 后的历史记录图:

        编辑


2. 合并分支

模拟你已经完成了 iss53 的全部工作,并打算将其合并到 master 分支。

  1. 切换到 master 分支并合并 iss53
    1. 合并前:

      编辑

    2. git checkout master

    3. git merge iss53

    4. 合并后:

      编辑

    5. 三方合并:当两个分支的提交历史分叉时,Git 需要做三方合并,使用两个分支的末端快照和公共祖先来合并。与快进合并不同,Git 会创建一个新的合并提交,它有多个父提交。

    6. 删除 iss53分支:git branch -d iss53


3. 遇到冲突时的合并分支

模拟合并时并不顺利,出现了冲突:对同一个文件的同一个部分进行了不同的修改,Git 就没法干净的合并它们。

$ git merge iss53
Auto-merging index.html
CONFLICT (content): Merge conflict in index.html
Automatic merge failed; fix conflicts and then commit the result.

  1. 查看冲突:使用 git status命令查看冲突的原因:
$ git status
On branch master
You have unmerged paths.
  (fix conflicts and run "git commit")

Unmerged paths:
  (use "git add <file>..." to mark resolution)

    both modified:      index.html

no changes added to commit (use "git add" and/or "git commit -a")

  1. 解决冲突
    1. 打开有冲突的文件,Git 会在冲突部分插入特殊标记:
<<<<<<< HEAD:index.html
<div id="footer">contact : email.support@github.com</div>
=======
<div id="footer">
please contact us at support@github.com
</div>
>>>>>>> iss53:index.html

    1. 你需要选择保留一个版本的内容,或合并两者的内容。解决后,删除冲突标记(<<<<<<<, =======, >>>>>>>)。
  1. 标记冲突已解决:
    1. git add将解决后的冲突标记为已解决:git add index.hmtl
  1. 完成合并并提交:
    1. git commit完成合并并提交。
    2. Git 会自动生成一个合并提交信息,例如:
Merge branch 'iss53'
Conflicts:
    index.html

  1. 使用图形化工具(可选):
    1. 如果需要,可以运行 git mergetool 启动图形化工具来帮助解决冲突:git mergetool

目录
相关文章
|
27天前
|
开发工具 git 开发者
图解Git——分支简介《Pro Git》
Git 分支是其核心特性之一,允许开发者从主开发线分离工作,避免干扰主线。传统版本控制系统创建分支效率低,而Git的分支创建和切换非常轻量高效。
69 9
|
1天前
|
开发工具 git 开发者
vscode+git解决远程分支合并冲突
通过这些详细步骤,您可以掌握如何使用VSCode和Git高效地解决远程分支合并冲突,提高开发效率和代码质量。希望这些内容对您的学习和工作有所帮助。
118 86
|
1月前
|
安全 Shell Linux
Git 基础——《Pro Git》
Git 是一个分布式版本控制系统,支持多种操作来管理和跟踪代码库的变化。以下是常用的操作和命令:
118 37
|
27天前
|
开发工具 git 开发者
图解Git——分布式Git《Pro Git》
分布式工作流程主要分为三种模式:集中式工作流、集成管理者工作流和主管与副主管工作流。集中式工作流中,所有开发者同步同一个中央仓库,通过拉取和提交协作;集成管理者工作流中,开发者拥有自己的仓库,通过 `fork` 和请求合并进行协作;主管与副主管工作流适用于大型项目,由主管最终合并代码,副主管负责各自模块。贡献代码时,需考虑活跃贡献者数量、工作流程、提交权限等因素,确保代码合并成功并遵循提交准则。
40 11
|
27天前
|
网络安全 Apache 开发工具
图解Git——服务器上的Git《Pro Git》
Git 远程仓库及通信协议简介:远程仓库为团队协作提供平台,支持共享代码。常见形式为裸仓库,仅保存 Git 元数据。Git 支持多种协议,包括本地协议(适合局域网)、HTTP/HTTPS(推荐智能 HTTP,安全易用)、SSH(企业内部协作首选)和 Git 协议(高效只读访问)。选择协议需根据协作需求、安全性和配置难度权衡。此外,搭建 Git 服务器涉及创建裸仓库、上传至服务器、初始化共享仓库等步骤。生成 SSH 公钥、配置服务器及使用 GitWeb 或 GitLab 等工具可进一步增强功能。第三方托管服务如 GitHub 提供便捷的托管选项,适合快速启动和开源项目。总结而言,自行运行服务器提
37 11
|
27天前
|
自然语言处理 开发工具 git
图解Git——变基《Pro Git》
变基(rebase)是Git中用于将一系列提交“重新播放”到另一个分支上的操作,使提交历史更加线性整洁。其基本操作为`git rebase &lt;目标分支&gt;`,可将当前分支的修改基于目标分支重新应用;复杂场景下使用`git rebase --onto &lt;新基底&gt; &lt;旧基底&gt; &lt;分支&gt;`,将特定提交从旧基底移动到新基底。
45 10
|
27天前
|
安全 开发工具 git
图解Git——分支管理《Pro Git》
分支管理是 Git 中的重要机制,支持并行开发和清晰的工作流。常用命令包括:`git branch` 列出所有分支,`git branch -v` 查看最后一次提交,`git branch --merged` 和 `git branch --no-merged` 分别查看已合并和未合并的分支。创建新分支用 `git branch &lt;branch-name&gt;`,删除分支用 `git branch -d`(已合并)或 `-D`(强制删除)。建议定期清理已完成任务的分支,保持代码库整洁,并使用有意义的分支命名规范。注意强制删除未合并分支时可能丢失数据。
31 5
|
27天前
|
存储 项目管理 开发工具
图解Git——分支开发工作流《Pro Git》
分支开发工作流利用Git的分支功能,支持灵活的项目管理。长期分支如`master`和`develop`分别保存稳定和开发中的代码;短期主题分支用于开发单一特性或修复问题,完成后合并到主分支。此模式确保代码稳定性,支持并行开发、便于审查和灵活调整。建议维护明确的长期分支,保持主题分支短小精悍,并定期清理无用分支。配置上可保护关键分支,遵循命名规范。
52 7
|
27天前
|
存储 缓存 Java
图解Git——远程分支《Pro Git》
远程分支是 Git 中用于管理分布式协作的关键概念。远程引用指向远程仓库中的分支和标签,常用 `git ls-remote` 或 `git remote show` 查看。日常开发中,通常使用远程跟踪分支(如 `origin/main`)与远程分支交互,简化远程仓库状态的管理和使用。远程跟踪分支记录远程分支的状态,但本身只读。
25 6
|
4月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
173 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令