Git实战004branch分支操作详解
什么是分支
分支指在主干道上分出来的支线,可以通往不同的地方也可以走向到同一个终点(只是实现的路线不同而已)。在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可以查看所有分支,其中带号代表当前的工作分支,如果想查看分支详情可以使用指令:gitbranchv可以查看包括分支指向的ID及提交信息。
切换分支
要使用分支我们就需要先切换到该分支上,使用指令gitcheckout分支名可以实现切换的分支。其本质就是修改了HEAD指针的指,将其切换到分支上来向并将工作区的内容指向了分支最后一次提交的快照内容。这时我们在进行提交时master分支就不再移动了,而是分支在随着提交操作移动。使用指令:gitcheckoutb分支名可以直接创建并切换到指定分支,相当于执行了新建分支和切换分支两个命令。
分支合并
当分支完成了阶段性的开发完并调试好后我们就可以进行合并了,使用指令:gitmerge分支名可以将指定分支合并到当前分支。注意这里是提交到当前分支,所以合并之前一定要确认下当前位于哪个分支上。如果要合并到master分支就需要先切换到master分支上,再执行gitmerge分支名合并操作。当合并(merge)发生时会产生新的提交(commit),当前分支会自动向前移动并生成新的分支合并记录了。合并不会影响被合并的分支,可以重新切换到该分支继续提交修改。
删除分支
当分支任务完成并与其他分支合并之后,如果该分支不再参与后续工作或者不需要该分支时就可以进行删除。利用指令:gitbranchd分支名可以删除指定分支,当然删除分支前需要先切换到其他分支才能进行删除操作。如果要强制删除分支的话可以使用指令:gitbranchD分支名,不管该分支有没有合并到当前分支的提交记录都进行删除。
恢复分支
对于已经有提交记录的分支删除后,实际上只是删除指针其commit记录还被保留,恢复之前我们可以通过指令:gitreflog查找该分支最后一次提交时的ID(最前面的hash值),我们可以根据ID创建新的分支来恢复之前的分支数据。恢复指令为:gitbranch分支名hash值,当然你也可以从远程仓库重新clone一份。
总结:
分支可以从主线上分离开来,在不影响主线的同时继续工作。在分支上开发并调试好了后再合并到主分支,那么每个人就可以负责不同的模块开发而不会影响到别人。所以利用分支不仅可以高效的管理项目资源,也可以更好的协调人力进行并行开发,提高开发效率降低开发周期。以上内容是小编给大家分享的【Git实战004:branch分支操作详解】,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。
iOS15。1Beta2发布解决2大问题今天凌晨,苹果向开发者推送了iOS15。1beta2更新,与上次更新时隔一周的时间。本次更新的版本号为:19B5052f,这次更新,主要解决2个问题:1,苹果……
或面临巨额罚款!传苹果(AAPL。US)因其NFC芯片面临欧智通财经APP获悉,据知情人士透露,苹果(AAPL。US)将因其NFC芯片技术而受到欧盟反垄断指控的打击,此举可能使该公司面临巨额罚款的风险,并可能迫使其对竞争对手开放移动支付……
被恶意开通苏宁易购免密支付的后续9月28日晚被盗刷后,担心银行账号泄露导致更多款项损失,所以当晚我在还没来得及思考问题发生根源情况下,把光大银行卡上的钱全部转到了工商银行,然后关闭了微信和支付宝与光大银行的账……
方舟子为什么会被别人骂的那么惨?方舟子作为中国科技界民间纪检组长。从美利坚留学归来,一出江湖,化无形之剑,专打名人公知,招招致其要害,使其求生不得,求死不能,身败名裂,贻笑天下!我发现方组长虽说功夫了得……
GovsJavavsC语法对比1。说明最近在学习Go,在学习的过程中为了加快学习速度、将新知识添加到已有知识体系架构中,总是会拿Go和其他开发语言进行对比,最终进行总结,于是就有了这篇文章。对于每一个……
对抗OpenSea?AndreCronje在Fantom发布Odaily星球日报译者余顺遂本月早些时候,前产品经理NateChastain被指控进行内幕交易,他知道哪些会出现在OpenSea的主页上,并涉嫌买卖这些NFT以赚取约6……
苹果首次在美国以外出售官翻版iPhone财经网科技9月22日讯,据IT之家援引9to5mac消息发现,苹果现已开始在加拿大在线商店出售官翻认证翻新版iPhone。自2016年开始,苹果就开始在美国在线商店出售官翻iP……
6个提效开发的JavaScript杀手函数1。校验一个元素是否在可视区域内网页开发时,常常需要了解某个元素是否进入了视口(viewport),即用户能不能看到它。可以使用IntersectionObserver这……
让人怀念的战斗机青春回忆杀这个是十八年前的事了,那时候手机刚刚普及。青春年少的我看见雨后春笋的手机特别羡慕人家。不过那时候手机真的比较贵的,用奢侈品来比喻都不为过,在乡镇大众价格一千多,……
安庆衡智能汽车芯片受制于人汽车产业急需跨界融合新京报贝壳财经讯(记者林子)2月25日,在中国电动汽车百人会论坛媒体沟通会上,中国汽车工业咨询委员会主任、北汽集团原董事长、中国电动汽车百人会理事安庆衡表示,智能汽车的发展仍然……
国产液晶电视哪个牌子好国产液晶电视机排名国产液晶电视哪个牌子好?目前市场上国产液晶电视机消费者比较信任的国产品牌有海信、创维、TCL、海尔、康佳等品牌,接下来就详细为大家介绍一下国产液晶电视机排名靠前的品牌吧(以下排……
微信及QQ承担政府部门日常的通知手段,如果腾讯封禁账号导致国没有责任。国家政务通知的渠道,是国家自有渠道,包括机要文件通知和内部电话网络通知等等。腾讯没有担负保障国家政务通讯渠道顺利的义务,国家也没有向腾讯购买此类服务。所以腾讯没有任何……