Git分支管理

4 篇文章 0 订阅

1. 创建分支

git branch 分支名

image-20240523090856436

masterdev指向同一个commit id,这是因为master指向的是最新提交,dev指向自己最新一次提交

image-20240523091447626

2. 切换分支

git checkout 分支名

image-20240523094133972

3. 合并分支

git merge 分支名

image-20240523100635247

4. 删除分支

git branch -d 分支名

如果处于当前分支下,是不能删除的

image-20240523102021193

创建、合并、删除分支都是很快的,当使用某个分支完成某个任务的时候,合并之后再删掉,这个虽然和master分支的效果一样,但是更安全

5. 分支冲突

image-20240523105339315

  • <<<<<<< HEAD=======中间的表明在当前分支的冲突内容
  • =======>>>>>>> dev1中间的表明是dev1分支冲突的内容

git没放解决这个问题,需要开发者自己决定

image-20240523110116120

此时状态:

image-20240523110325291

出现分支冲突时,需要手动解决,并且再次提交一次

6. 分支管理策略

合并模式

fast forward

直接merge合并,默认采用的是fast forward

image-20240523113612207

这样并不能看出到底是最新提交还是merge进来的

no-fast forward

git merge --no-ff -m "messgae" 分支名

image-20240523113658869

image-20240523115635588

分支策略

master主分支必须是稳定的,是发布的版本,日常维护是在其他分支维护

7. 分支bug

当在一个分支上进行开发时,master分支突然报bug了,此时并不能在当前分支解决bug,因为这个分支是用来开发的。

所以要再建立一个分支,来修复bug,修复完毕之后,合并分支,再删除这个修改bug的分支。

但这里的问题是,在开发的分支上,目前还无法提交

image-20240523121650791

先将当前开发分支内容保存:

git stash

保存的内容是要已经被git追踪管理的文件

修复bug…:

image-20240523122548280

查看临时存储区内容:

git stash list

image-20240523123011108

恢复存储内容:

git stash pop

image-20240523123251971

  • 开发完毕之后,先用开发分支合并master分支,这样就算合并冲突了,也不会影响到master分支
    image-20240523124317349
  • 合并完毕之后,再用master分支合并开发分支,冲突问题在开发分支中已经解决了,此时就不会再冲突
  • 最后删除开发分支和修复bug分支

8. 强制删除分支

开发到一半的时候,如果不需要当前分支功能了,git branch -d dev是不能进行删除的,因为git对分支进行了保护

采用-D进行强制删除git branch -D dev

image-20240523124541485

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

加法器+

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值