产业气象站|Git实战004:branch分支操作详解
什么是分支
分支指在主干道上分出来的支线 , 可以通往不同的地方也可以走向到同一个终点(只是实现的路线不同而已) 。 在Git中分支指向团队开发中的个体 , 每位开发者都可以拥有属于自己的分支 , 在开发的时候不会影响其他分支的开发进度 。 当分支完成了阶段性工作后可以合并到上级分支(功能开发完成并调试OK) , 这个上级分支一般指Git默认创建的Master分支 , 该分支一般不参与开发只用作项目的管理、维护、合并、发布 。
文章图片
?Git分支
Git分支并不是将所有数据进行复制一份 , 而是一个指向提交(commit)对象的指针 。 在执行暂存(gitadd)操作时Git会计算每个文件的效验值和将当前版本的文件快照保存到暂存区域等待提交 , 执行(gitcommit)操作时Git会将计算好的效验值和快照保存成一个树对象(每个commit对象包含所指向的tree对象的hash值 , 每个tree对象包含所指向的blob对象的hash值) , 该对象包含指向暂存内容快照的指针、commit父级对象指针及提交者的用户信息等 。 所以Git保存的不是文件的变化或者差异 , 而是一系列不同时刻的文件快照 。 Git分支的创建和切换其实只是简单的创建指针和找指针 , 所以创建分支以及切换分支几乎都是瞬间完成 。 通过指针找到所指向的commit对象 , 将工作空间恢复成该commit对象所指的文件快照 。
文章图片
Git提交Git把每次提交串成一条时间线 , 每提交(commit)一次就会向前移动并形成一条分支 。 每次提交会生成一个ID(hash值)记录当前的位置 , HEAD则会指向最后一次提交的位置(也就是当前的分支) 。
文章图片
创建分支
分支的创建本质上只是创建了一个指向提交(commit)对象的指针 , Git在初始化的时候自动为我们创建了第一个master分支以及指向master的指针HEAD(HEAD通常指向当前提交的分支) 。 使用指令:gitbranch<分支名>可以创建一个分支 , 该分支指向当前提交对象的分支master(也就是在master上建立了一条分支) 。 VSCode创建分支也简单 , 在左下角点击分支就会弹出下拉框 , 这里可以创建新的分支也可以选择现有的分支切换 。
文章图片
?查看分支使用指令:gitbranch可以查看所有分支 , 其中带*号代表当前的工作分支 , 如果想查看分支详情可以使用指令:gitbranch-v可以查看包括分支指向的ID及提交信息 。
文章图片
?切换分支
要使用分支我们就需要先切换到该分支上 , 使用指令gitcheckout<分支名>可以实现切换的分支 。 其本质就是修改了HEAD指针的指 , 将其切换到分支上来向并将工作区的内容指向了分支最后一次提交的快照内容 。 这时我们在进行提交时master分支就不再移动了 , 而是分支在随着提交操作移动 。 使用指令:gitcheckout-b<分支名>可以直接创建并切换到指定分支 , 相当于执行了新建分支和切换分支两个命令 。
文章图片
?分支合并当分支完成了阶段性的开发完并调试好后我们就可以进行合并了 , 使用指令:gitmerge<分支名>可以将指定分支合并到当前分支 。 注意这里是提交到当前分支 , 所以合并之前一定要确认下当前位于哪个分支上 。 如果要合并到master分支就需要先切换到master分支上 , 再执行gitmerge<分支名>合并操作 。 当合并(merge)发生时会产生新的提交(commit) , 当前分支会自动向前移动并生成新的分支合并记录了 。 合并不会影响被合并的分支 , 可以重新切换到该分支继续提交修改 。
推荐阅读
- DIGITIMES|“长腿”机器人跳跃巡视农地揪害虫
- 辉常观察|产业互联网:区块链与数字货币的分水岭,原创
- 精选热点资讯|服务江西产业发展,晏斌:围绕直播大赛
- 爱集微|投向智能制造/人工智能等领域,欣旺达子公司参与设立产业基金
- 产业气象站|华为新款移动路由双网双通在线,告别断网烦恼,手机一碰就能上网
- 中国蓝新闻|“薅羊毛”入刑越城法院一审宣判,坚决斩断灰色产业链
- 上游新闻|智博会上将签约GPP芯片生产项目,关注智博会|30多家电子产业企业构建梁平电子信息产业链
- 北京商报网|2020中国电信5G产业创新联盟北京站启动
- 家族战队|就读懂了湖南互联网产业,读懂了这些话
- 52未来社区|中国全面支持的半导体产业会怎么样?,新导航芯片领先GPS