详解|Git实战004:branch分支操作详解


什么是分支
分支指在主干道上分出来的支线 , 可以通往不同的地方也可以走向到同一个终点(只是实现的路线不同而已) 。 在Git中分支指向团队开发中的个体 , 每位开发者都可以拥有属于自己的分支 , 在开发的时候不会影响其他分支的开发进度 。 当分支完成了阶段性工作后可以合并到上级分支(功能开发完成并调试OK) , 这个上级分支一般指Git默认创建的Master分支 , 该分支一般不参与开发只用作项目的管理、维护、合并、发布 。

详解|Git实战004:branch分支操作详解
本文插图
?Git分支

Git分支并不是将所有数据进行复制一份 , 而是一个指向提交(commit)对象的指针 。 在执行暂存(git add)操作时Git会计算每个文件的效验值和将当前版本的文件快照保存到暂存区域等待提交 , 执行(git commit)操作时Git会将计算好的效验值和快照保存成一个树对象( 每个commit对象包含所指向的tree对象的hash值 , 每个tree对象包含所指向的blob对象的hash值) , 该对象包含指向暂存内容快照的指针 、commit父级对象指针及提交者的用户信息等 。 所以Git保存的不是文件的变化或者差异 , 而是一系列不同时刻的文件快照 。 Git分支的创建和切换其实只是简单的创建指针和找指针 , 所以创建分支以及切换分支几乎都是瞬间完成 。 通过指针找到所指向的commit对象 , 将工作空间恢复成该commit对象所指的文件快照 。
详解|Git实战004:branch分支操作详解
本文插图

Git提交 Git把每次提交串成一条时间线 , 每提交(commit)一次就会向前移动并形成一条分支 。 每次提交会生成一个ID(hash值)记录当前的位置 , HEAD则会指向最后一次提交的位置(也就是当前的分支) 。

详解|Git实战004:branch分支操作详解
本文插图
创建分支

分支的创建本质上只是创建了一个指向提交(commit)对象的指针 , Git在初始化的时候自动为我们创建了第一个master分支以及指向master的指针HEAD(HEAD通常指向当前提交的分支) 。 使用指令: git branch &lt分支名&gt 可以创建一个分支 , 该分支指向当前提交对象的分支master(也就是在master上建立了一条分支) 。 VSCode创建分支也简单 , 在左下角点击分支就会弹出下拉框 , 这里可以创建新的分支也可以选择现有的分支切换 。
详解|Git实战004:branch分支操作详解
本文插图

?查看分支 使用指令:git branch 可以查看所有分支 , 其中带* 号代表当前的工作分支 , 如果想查看分支详情可以使用指令:git branch -v 可以查看包括分支指向的ID及提交信息 。

详解|Git实战004:branch分支操作详解
本文插图
?切换分支

要使用分支我们就需要先切换到该分支上 , 使用指令 git checkout &lt分支名&gt 可以实现切换的分支 。 其本质就是修改了HEAD指针的指 , 将其切换到分支上来向并将工作区的内容指向了分支最后一次提交的快照内容 。 这时我们在进行提交时master分支就不再移动了 , 而是分支在随着提交操作移动 。 使用指令:git checkout -b &lt分支名&gt 可以直接创建并切换到指定分支 , 相当于执行了新建分支和切换分支两个命令 。
详解|Git实战004:branch分支操作详解
本文插图

?分支合并 当分支完成了阶段性的开发完并调试好后我们就可以进行合并了 , 使用指令:git merge &lt分支名&gt 可以将指定分支合并到当前分支 。 注意这里是提交到当前分支 , 所以合并之前一定要确认下当前位于哪个分支上 。 如果要合并到master分支就需要先切换到master分支上 , 再执行git merge &lt分支名&gt 合并操作 。 当合并(merge)发生时会产生新的提交(commit) , 当前分支会自动向前移动并生成新的分支合并记录了 。 合并不会影响被合并的分支 , 可以重新切换到该分支继续提交修改 。


推荐阅读