Git速成学习第三课:创建与合并分支
本来第三课想记录一下远程仓库的创建与克隆0.0但是想了想还是不写了。
这里写一下分支管理中的创建与合并。
Git速成学习笔记整理于廖雪峰老师的官网网站:https://www.liaoxuefeng.com/
首先在版本提交的过程中,每一次提交,Git都会将他们传承一条时间线,这个时间线就是一个分支。
截止目前,我们只有一条时间线,在Git中,这个分支就叫做主分支master。HEAD严格意义来讲不是
指提交,而是指向master,master才是指向提交的。所以,HEAD指向的就是当前的分支。
一开始的时候,master分支就是一条线,Git用master指向最新的提交,再用HEAD指向master,就可以
确定当前的分支,以及当前分支的提交点:

每一次提交,master分支就会向前移动一步,这样,随着你不断提交,master分支的线越来越长。
当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master形同的提交,再把HEAD指向dev
就表示当前的分支在dev上:

Git创建一个分支很快,因为除了增加一个dev指针,改改HEAD的指向,工作区的文件没有任何变化!
但是从现在开始,对工作区的修改和提交就是针对dev分支了。比如新提交一次后,dev指针往前移动一步
而master不变:

假如我们在dev上的工作完成了,就可以把dev合并到master上。合并的方法也十分简单,就是将master指向dev的
当前提交,就完成了合并:

所以Git合并分支也很快!只需要修改指针,工作区内容也不变。
合并完成后,我们甚至可以删除dev分支。删除的分支就是把dev指针给删除掉,删掉后只剩下master分支:

Let's do it!
首先我们创建一个dev分支,然后再切换到分支:
$ git checkout -b dev
Switched to a new branch 'dev'
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev
$ git checkout dev
Switched to branch 'dev'
然后用git branch命令查看自己当前的分支:
$ git branch
* dev
master
git branch命令会列出所有的分支,当前分支前面会标出一个*符号
然后我们就可以在dev分支上正常提交,比如对readme.txt进行修改,
添加一行文本“Creating a new branch is quick”
然后提交:
$ git add readme.txt
$ git commit -m "branch test"
[dev b17d20e] branch test
1 file changed, 1 insertion(+)
现在,dev分支的工作完成,我们就可以切换回master分支:
$ git checkout master
Switched to branch 'master'
切换回master后,在查看一个文件readme.txt。刚才添加的内容不见了。因为刚才的提交在dev的分支上,
而master分支此刻的提交点并没有改变。如图所示:

现在我们就把dev分支的工作成果合并到master分支上:
$ git merge dev
Updating d46f35e..b17d20e
Fast-forward
readme.txt | 1 +
1 file changed, 1 insertion(+)
git merge命令用于合并指定分支到当前分支。合并后在查看readme.txt的内容,就可以看到,和dev分支的最新内容是完全一样的。
注意上面的Fast -forward信息,Git告诉我们 ,这次的合并是“快进合并”,也就是直接把master指向dev的当前提交,所以合并的速度非常快。
当然也不是每一次的提交都能Fast -forward,后面将会学习到其他的合并方式。
那么合并完后,就可以放心的删除dev分支了:
$ git branch -d dev
Deleted branch dev (was b17d20e)
删除后,查看branch,就只剩master分支了:
$ git branch
* master
因为创建合并还有删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删除分支,这就和
直接在master上面工作的效果是一样的,但过程更加安全。
switch
我们注意到切换分支使用git checkout <branch>,而前面讲过的撤销修改则是git checkout -- <file>,
同一个命令,有两种作用,确实有些让人迷惑。
实际上,切换分支的这个动作,用switch更加科学。因此最新的git版本提供git switch命令来切换分支:
$ git switch -c dev
直接切换到已有的master分支,可以使用:
$ git switch master
使用新的git switch命令,比git checkout要更容易理解。
Summary
Git鼓励大量使用分支:
查看分支 git branch
创建分支 git branch <name>
切换分支 git checkout <name> or git switch <name>
创建+切换分支 git checkout -b <name> or git switch -c <name>
合并某分支到当前分支 git merge <name>
删除分支 git branch -d <name>
Git速成学习第三课:创建与合并分支的更多相关文章
- Git速成学习第六课:Bug分支
Git速成学习笔记整理于廖雪峰老师的官网网站:https://www.liaoxuefeng.com/ 当你接到一个修复代码为101的任务的时候,很自然的你想创建一个分支issue-101来修复它,但 ...
- Git速成学习第五课:分支管理策略
Git速成学习笔记整理于廖雪峰老师的官网网站:https://www.liaoxuefeng.com/ 通常合并分支时,如果可能用Fast forward模式,但是在这种模式下,删除分支后,会丢掉分支 ...
- Git速成学习第四课:解决冲突
Git速成学习笔记整理于廖雪峰老师的官网网站:https://www.liaoxuefeng.com/ 我们继续练习,准备新的feature1分支. $ git checkout -b feature ...
- Git创建与合并分支,撤销修改
git回滚到指定版本并推送到远程分支(撤销已提交的修改,并已push) git reset --hard <commit ID号> git push -f git回滚到上一个版本并推送到远 ...
- Git速成学习第一课:创建版本库与版本回退
Git速成学习笔记整理于廖雪峰老师的官网网站:https://www.liaoxuefeng.com/ 我太困了0.0精神点再写...... /*我来啦!以后会陆续更新自己的学习笔记*/ Git是分布 ...
- Git速成学习第二课:管理修改与删除文件
Git速成学习笔记整理于廖雪峰老师的官网网站:https://www.liaoxuefeng.com/ 管理修改 首先我们需要明确,为什么说Git管理的是修改而不是文件呢? 我们首先对于已有的read ...
- Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search)
原文:Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...
- 使用git创建与合并分支
一.概述 学会使用git命令对项目进行创建分支,并在创建结束后合并到主分支上. 问:为什么要创建分支? 答:在原来的分支上创建一个自己的分支进行开发,在开发完毕后一次性合并到原先的分支,这样既保证安全 ...
- GIT 分支管理:创建与合并分支、解决合并冲突
分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN. 如果两个平行宇宙互不干扰,那对现在的你也没啥影响.不过,在某个时间点,两个平行宇宙合并 ...
随机推荐
- easyui-filebox上传图片到阿里
应用场景:在fixbox图片上传时在预览图片img标签底下点击按钮触发一下函数 参考:https://www.cnblogs.com/awzf/p/9843814.html js //修改该时上传产品 ...
- 2019牛客多校B generator 1——十进制快速幂
题目 已知 $x_i = ax_i + bx_{i-1}$,求 $x_n \% MOD$.($1\leq n\leq 10^{(10^6)}$) 分析 写成矩阵快速幂的形式,相当于求转移矩阵的 $n$ ...
- LNOI2018 劈配
主要思路为连反向边. 对于本题,贪心策略,依次决定每个人的最优解 但因为每人达到的最优解可能有多种方式,如果每个都尝试就会超时,所以只能先采取其中一种 并将这个方案连反向边,其它方案连正向边 这样对于 ...
- P1578 奶牛浴场 有障碍点的最大子矩形
这题咕咕了很久终于写了\(QwQ\) 思路:扫? 提交:2次 错因:数据差评,第一次把矩形的长宽搞反了竟然只有一个点没有\(A\). 题解: 显然能成为答案的矩形的边界一定有障碍点或者与大矩形边界重合 ...
- ADC-DAC
一,ADC 模拟信号 什么是模拟信号?主要是与离散的数字信号相对的连续的信号.模拟信号分布于自然界的各个角落,如每天温度的变化, 而数字信号是人为的抽象出来的在时间上不连续的信号.电学上的模拟信号是主 ...
- DUILib学习笔记---消息处理
WIN32下窗口消息循环 MSG msg = { 0 }; while( ::GetMessage(&msg, NULL, 0, 0) ) { ::TranslateMessage(& ...
- JavaWeb_(Mybatis框架)MyBatis整合Spring框架
MyBatis + Spring整合开发 a)使用Spring容器用单例模式管理Mybatis的sqlSessionFactory:b)使用Spring管理连接池.数据源等:c)将Dao/Mapper ...
- 两大主流开源分布式存储的对比:GlusterFS vs. Ceph
两大主流开源分布式存储的对比:GlusterFS vs. Ceph 存储世界最近发生了很大变化.十年前,光纤通道SAN管理器是企业存储的绝对标准,但现在的存储必须足够敏捷,才能适应在新的基础架构即服务 ...
- Leetcode题目300.最长上升子序列(动态规划-中等)
题目描述: 给定一个无序的整数数组,找到其中最长上升子序列的长度. 示例: 输入: [10,9,2,5,3,7,101,18] 输出: 4 解释: 最长的上升子序列是 [2,3,7,101],它的长度 ...
- mvc partialView断点调试问题
mvc中的partialview 在前端f12调试时,默认看不到代码的. 在Js中加上debugger; 调试时会走到断点,多出个VM打头的局部视图页面.