| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 开发工具 -> Git的branch操作详解与总结 -> 正文阅读 |
|
[开发工具]Git的branch操作详解与总结 |
Git教程之分支操作文章目录分支理论分支 (branch)在开发软件时,可能有多人同时为同一个软件开发功能或修复BUG,可能存在多个Release版本,并且需要对各个版本进行维护。Git的分支功能可以支持同时进行多个功能的开发和版本管理。 分支是为了将修改记录的整体流程分叉保存。分叉后的分支不受其他分支的影响,所以在同一个数据库里可以同时进行多个修改。分叉的分支可以合并 在数据库进行最初的提交后, Git会创建一个名为main的分支。因此之后的提交,在切换分支之前都会添加到main分支里。
分支的运用分支 (“Merge分支”和 “Topic分支” ) 的运用规则。 Merge分支Merge分支是为了可以随时发布release而创建的分支,它还能作为Topic分支的源分支使用。保持分支稳定的状态是很重要的。如果要进行更改,通常先创建Topic分支,最后合并到Merge分支上。通常,大家会将master分支当作Merge分支使用。 Topic分支Topic分支是为了开发新功能或修复Bug等任务而建立的分支。若要同时进行多个的任务,则创建多个的Topic分支。 分支的切换若要切换作业的分支,就要进行checkout操作。进行checkout时,git会从工作树还原向目标分支提交的修改内容。checkout之后的提交记录将被追加到目标分支。 HEADHEAD指向的是现在使用中的分支的最后一次更新。通常默认指向master分支的最后一次更新。通过移动HEAD,就可以变更使用的分支。
stash还未提交的修改内容以及新添加的文件,留在索引区域或工作树的情况下切换到其他的分支时,修改内容会从原来的分支移动到目标分支。但是如果在checkout的目标分支中相同的文件也有修改,checkout会失败的。这时要么先提交修改内容,要么用stash暂时保存修改内容后再checkout。 stash是临时保存文件修改内容的区域。stash可以暂时保存工作树和索引里还没提交的修改内容,您可以事后再取出暂存的修改,应用到原先的分支或其他的分支上。 分支的合并merge或rebase两种方法。 merge
使用merge可以合并多个历史记录的流程。 fast-forward(快进)合并合并 bugfix分支到master分支时,如果master分支的状态没有被更改过。 bugfix分支的历史记录包含master分支所有的历史记录,把master分支的位置移动到bugfix的最新分支上,Git 就会合并。
master分支的历史记录有可能在bugfix分支分叉出去后有新的更新,则修改内容需要汇合起来,master分支的HEAD会移动到该提交上。 rebase
rebase bugfix分支到master分支, bugfix分支的历史记录会添加在master分支的后面。提交X和Y有可能会发生冲突,所以需要修改各自的提交时发生冲突的部分。 rebase之后,master的HEAD位置不变。因此,要合并master分支和bugfix分支,即是将master的HEAD移动到bugfix的HEAD这里。 一些建议:
A successful Git branching model来源:a-successful-git-branching-model
分支实践创建分支
查看当前分支不指定参数直接执行branch命令。前面有*的就是现在的分支。
切换分支执行checkout命令以切换分支。
合并分支执行merge命令以合并分支。
删除分支在branch命令指定-d选项执行,以删除分支。
用rebase合并取消刚才的合并
rebase合并
rebase的时候,修改冲突后的提交不是使用commit命令,而是执行rebase命令指定 --continue选项。若要取消rebase,指定 --abort选项。
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 20:53:43- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |