美文网首页
Git的分支管理

Git的分支管理

作者: YLiuY | 来源:发表于2019-03-01 21:06 被阅读0次

分支的创建与合并

当创建一个仓库后,会存在一个主分支即master分支。HEAD严格上说并没有指向提交,而是指向master分支,master指向提交版本。

image.png

首先,我们创建一个dev分支,然后切换到dev分支:

git checkout -b dev   #创建一个dev分支

git checkout命令加上-b参数表示创建并切换,相当于以下两个命令

git branch dev     #新建分支
git checkout dev  #切换分支

然后,可以利用git branch命令查看当前分支:

$ git branch
*dev   #会列出所有分支,当前分支上会出现一个`*`号
master
image.png
dev分支的工作完成了,我们就可以切换到master分支
git checkout master
image.png

切换到master分支后,发现先前工作没有了。因为先前工作在dev分支完成的,现在我们需要将dev的成果合并到master分支上。

$ git merge dev
Updating d46f35e..b17d20e
Fast-forward
 readme.txt | 1 +
 1 file changed, 1 insertion(+)

git merge指令用于将当前分支与指定分支合并,可以添加-m '修改信息'参数。
当合并完成后,需要放心的删除dev分支了。

git branch -d dev

通常时候合并分子时,git会采用Fast forword模式,这种模式会删掉分支后,会丢失分支信息。如果禁用Fast forword模式,git会在merge时生成一个新的commit,这样就可以看出分支信息。

$ git merge --no-ff -m "merge with no-ff" dev

因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。

image.png

在实际开发中,我们应该按照几个基本原则进行分支管理:
首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;
你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

所以,团队合作的分支看起来就像这样:


image.png

相关文章

  • git常用命令

    分支管理 git 切换分支 git 查看远程分支 git 查看本地分支 git 创建本地分支 git 删除本地分支...

  • Git命令整理

    Git命令 ———————————————— git配置: git基本步骤: git分支管理: 创建分支命令: 切...

  • GIT分支管理

    GIT 分支管理 参考:在阿里,我们如何管理代码分支?GitHub Flow & Git Flow 基于Git...

  • git常用操作

    Basic Operation 分支管理切换分支git checkout git checkout -b #...

  • git提交代码规范管理

    GIT分支管理 git远程分支主要包括:master develop fixbugmaster:整个项目主分支,...

  • 2021-11-30

    一、分支管理 1、创建分支 git branch 2、查看分支 git branch...

  • git分支仓库管理

    git分支和标签管理 创建分支 git branch banchName git checkout -b bra...

  • git分支管理与使用规范

    git分支管理与使用规范 分支管理 flow git flow github flow gitlab flow f...

  • git 创建分支提交远程分支

    Git创建与管理远程分支 1.创建本地分支 git branch 分支名,例如:git branch 2.0.1....

  • 2016-06-24 阅读整理

    Git Git 基础命令Git 分支管理Git 分支合并Git 公钥提交Git 常用技巧Git 设置别名 Andr...

网友评论

      本文标题:Git的分支管理

      本文链接:https://www.haomeiwen.com/subject/agpjuqtx.html