当前位置:首页 > 技术分析 > 正文内容

Git实战004:branch分支操作详解(git branch -f)

ruisui884个月前 (02-03)技术分析16

什么是分支

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

Git分支

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

Git提交

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

创建分支

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

查看分支

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

切换分支

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

分支合并

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

删除分支

当分支任务完成并与其他分支合并之后,如果该分支不再参与后续工作或者不需要该分支时就可以进行删除。利用指令:git branch -d <分支名> 可以删除指定分支,当然删除分支前需要先切换到其他分支才能进行删除操作。如果要强制删除分支的话可以使用指令:git branch -D <分支名> ,不管该分支有没有合并到当前分支的提交记录都进行删除。

恢复分支

对于已经有提交记录的分支删除后,实际上只是删除指针其commit记录还被保留,恢复之前我们可以通过指令:git reflog查找该分支最后一次提交时的ID(最前面的hash值),我们可以根据ID创建新的分支来恢复之前的分支数据。恢复指令为:git branch <分支名> <hash值> ,当然你也可以从远程仓库重新clone一份。

总结:

分支可以从主线上分离开来,在不影响主线的同时继续工作。在分支上开发并调试好了后再合并到主分支,那么每个人就可以负责不同的模块开发而不会影响到别人。所以利用分支不仅可以高效的管理项目资源,也可以更好的协调人力进行并行开发,提高开发效率降低开发周期。以上内容是小编给大家分享的【Git实战004:branch分支操作详解】,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1259.html

分享给朋友:

“Git实战004:branch分支操作详解(git branch -f)” 的相关文章

Vue3 如何实现父子组件传值?

在Vue 3中,要实现父子组件传值效果主要通过props和emit两种机制来实现,下面我们就来详细介绍一下这两种机制。父组件向子组件传值propsprops是Vue组件的一种机制,主要的作用就是实现从父组件向子组件传递数据值,在父组件上通过在子组件标签上定义属性来实现数据属性值的传递,在子组件中通过...

带你五步学会Vue SSR

作者:liuxuan 前端名狮转发链接:https://mp.weixin.qq.com/s/6K6GUHcLwLG4mzfaYtVMBQ前言SSR大家肯定都不陌生,通过服务端渲染,可以优化SEO抓取,提升首页加载速度等,我在学习SSR的时候,看过很多文章,有些对我有很大的启发作用,有些就只是照搬官...

jvm疯狂吃内存,到底是谁的锅?

jvm应该是每一个java程序员都需要掌握的内容,但是在没有遇到问题之前,很多都是基于理论的,唯有实战才能增加个人的知识储备。本文是从一个角度来分析是谁在狂吃内存,希望对你有所帮助。本文是易观技术人员注意到一台开发机上各个微服务进程占用内存很高,随即便展开了调查......ps:本文来源于:http...

最快清除数组空值?分享 1 段优质 JS 代码片段!

本内容首发于工粽号:程序员大澈,每日分享一段优质代码片段,欢迎关注和投稿!大家好,我是大澈!本文约 600+ 字,整篇阅读约需 1 分钟。今天分享一段优质 JS 代码片段,用最简洁的代码清除了数组中的空值。老规矩,先阅读代码片段并思考,再看代码解析再思考,最后评论区留下你的见解!const arr...

SpringBoot2.X+Vue+UniAPP,全栈开发医疗小程序

//xia仔のke:chaoxingit.com/208/全栈开发医疗小程序:利用Spring Boot 2.X、Vue和UniApp在当今数字化时代,医疗行业也在不断地迈向信息化和智能化的方向。开发一款医疗小程序,能够为用户提供便捷的医疗服务和信息查询,为医疗机构提供高效的管理和服务渠道。本文将介...

微信开发的五大价值应用

企业形象展示微网站是企业在移动互联网时代完美展示企业及品牌形象的最佳选择,表现内容丰富、实时更新、形式多样化,保证品牌形象的有效传播!微网站带来的轻营销模式,更适应现代网站的发展模式,所以微网站的开发也具有更好的商业营销效果,其面对的受众是7亿多的微信用户,蕴含着无限的商机。将企业微网站植入微信公众...