Git 保存的不是文件的变化或者差异,而是一系列不同时刻的文件快照,某一次的提交指向这处时刻的文件快照,看起来就像每次提交都保存了当时的文件,连续的提交形成一条长链

分支 指向某一个特定的提交,不同的分支可以指向同一个提交,此时它们是相同的;不指向一个提交的分支,按提交的顺序排序,指向提交靠前的分支在指向提交靠后的分支前面;由于不同的分支都可以提交新的提交,这些就打乱原来链状的提交,开成分叉,这时回到原来的分支,需要合并,丢弃不用分支要删除,当然首先得创建分支。

X-k_@HK ~/Desktop/Hk (master)
$

windows 下的 Git 的命令行除了当前仓库的路径,后面的括号里显示的就是当前分支

master 是 Git 默认创建的分支,在第一次提交或克隆自动创建

git branch name 创建分支,下面创建 dev 分支

$ git branch dev

查看分支,带 * 的是当前分支

$ git branch
dev
* master

切换分支

$ git checkout dev
Switched to branch 'dev'

现在可以在 dev 分支上开发,待开发到一定程度时,没什么BUG,比较稳定时,可以合并到主分支上。

e.g

在 dev 分支修改 t.c (添加一行 "float c;")后提交,切回 master 分支合并到 master 分支。

git merge dev 把 dev 合并到当前分支

$ git commit -a -m float
[dev 06a9033] float
1 file changed, 1 insertion(+)
$ git status
On branch dev
nothing to commit, working directory clean $ git checkout master
Switched to branch 'master' $ git merge dev
Updating 11891ac..06a9033
Fast-forward
t.c | 1 +
1 file changed, 1 insertion(+)
$ git log --format="%h %s" --graph
* 06a9033 float
* 11891ac add t.c
* 9201c98 update readme.md
* 2e07671 first commit

现在提交还在一条链上,合并只是把 master 分支的指向 dev 分支指向的提交

那么现在试下在 master 分支和 dev 分支同时修改 t.c 并提交,然后合并,看看会发生什么

在 master 分支修改 float > long,提交 ‘long’

$ git log --format="%h %s" --graph
* a779b07 long
* 06a9033 float
* 11891ac add t.c
* 9201c98 update readme.md
* 2e07671 first commit

在 dev 分支修改 float > double ,提交 ‘double’

$ git log --format="%h %s" --graph
* 87531a3 double
* 06a9033 float
* 11891ac add t.c
* 9201c98 update readme.md
* 2e07671 first commit

dev 合并到 master 分支

$ git merge dev
Auto-merging t.c
CONFLICT (content): Merge conflict in t.c
Automatic merge failed; fix conflicts and then commit the result.

合并遇到冲突,此时 Git 做了合并,但是没有自动地创建一个新的合并提交。 Git 会暂停下来,等待你去解决合并产生的冲突。用 git status 命令来查看那些因包含合并冲突而处于未合并(unmerged)状态的文件:

$ git status
On branch master
You have unmerged paths.
(fix conflicts and run "git commit")
Unmerged paths:
(use "git add <file>..." to mark resolution)
both modified: t.c
no changes added to commit (use "git add" and/or "git commit -a")

Git 会在有冲突的文件中加入标准的冲突解决标记,这样你可以打开这些包含冲突的文件然后手动解决冲突。出现冲突的文件会包含一些特殊区段,看起来像下面这个样子:

int a;
int b;
<<<<<<< HEAD
long c;
=======
double c;
>>>>>>> dev

"这表示 HEAD 所指示的版本(也就是你的 master 分支所在的位置,因为你在运行 merge 命令的时候已经检出到了这个分支)在这个区段的上半部分(======= 的上半部分),而 dev 分支所指示的版本在 ======= 的下半部分。

保留了其中一个分支的修改,并且 <<<<<<< , ======= , 和 >>>>>>> 这些行要完全删除了。"

修复后,正常提交就可以了,这时的历史是这样的

$ git log --format="%h %s" --graph
* 0451275 merge
|\
| * 87531a3 double
* | a779b07 long
|/
* 06a9033 float
* 11891ac add t.c
* 9201c98 update readme.md
* 2e07671 first commit

最后的选项 --graph 添加了一些ASCII字符串来形象地展示分支、合并历史

现在 dev 分支没有了,就可以删掉了

$ git branch -d dev
Deleted branch dev (was 87531a3).

如果无法删除,可以尝试使用 -D 强制删除

git branch 还可以用选项 -a 查看全部分支(包括远程分支),

-v 查看分支和分支最后一次提交

高级参考

  1. 分支Git Git 分支 - 分支简介
  2. 分支合并 Git 分支 - 分支的新建与合并
  3. 高级合并 Git 工具 - 高级合并
  4. 分支开发工作流参考 Git 分支 - 分支开发工作流

Git 分支的更多相关文章

  1. Git分支管理

    一.Git分支的使用 查看分支: git branch 创建分支: git branch branch1 切换到branch1 git checkout branch1 再用git branch查看, ...

  2. Git分支的前世今生

    摘自Jack__CJ  CSDN博客,写得很好,保存一下. 导读 几乎所有的版本控制系统都以某种形式支持分支. 使用分支意味着你可以把你的工作从开发主线上分离开来,以免影响开发主线. 在很多版本控制系 ...

  3. GIT分支管理模型

    GIT分支管理模型 link: git-branching-model 主分支(Main branches) 项目两个常驻分支: master 主干分支(锁定),仅用于发布新版本,平时不能在上面干活, ...

  4. Git详解之三 Git分支

    相关文档 — 更多 Git 基础培训.ppt GIT 使用经验.ppt GIT 介绍.pptx GIT 分支管理是一门艺术.docx Eclipse上GIT插件EGIT使用手册.docx git/gi ...

  5. git初体验(三)git分支

    分支的理念就是分身,就像孙悟空拔出猴毛变出很多跟自己一模一样的猴子,然后每个猴子做自己的事情互不干涉,等到所有猴子做完之后,猴子集合来合并劳动成果,然后悟空就把那些猴子猴孙门统统收回了. 你创建了一个 ...

  6. 如何在终端实时展现git分支

    在微博上看到ghosTM55在终端可以实时展现出当前运行的分支,觉得很奇特,于是google了一把.这里面存在两个内容,第一个bash,第二个是git bash基础: 了解到linux的shell存在 ...

  7. php 通过exec 创建git分支失败

    今天给我们自己的发布系统增加一个新建分支的功能,操作比较简单,但是使用php执行shell命令的时候总是无法push分支到远程,但是登陆服务器执行却是可以的 新建分支命令如下 git fetch -- ...

  8. 开发与测试整体过程中的Git分支merge流程

    开发与测试整体过程中的Git分支merge流程 Git分支merge之开发流程 首先在Gitlab上有个仓库存储着原始的项目代码,其中包含一个叫master的分支.然后可能按功能进行分配,由不同的开发 ...

  9. Git 分支管理是一门艺术

    转载: Git 分支管理是一门艺术 1 要确保:团队成员从主分支(master)获得的都是处于可发布状态的代码,而从开发分支(develop)应该总能够获得最新开发进展的代码. 2 "辅助分 ...

随机推荐

  1. memcached安装

    memcached安装 一.安装gcc # yum -y install gcc 二.安装libevent # wget http://www.monkey.org/~provos/libevent- ...

  2. js设计模式总结-单例模式

    单例模式 解决的问题 保证实例只有一个,避免多个实现,从全局来看,这个实例的状态是唯一的. 实现原理 设置一个变量来记录实例,通过检测该变量是否为空来决定是否创建实例 非透明单例 所谓非透明就是用户在 ...

  3. kegg-kass注释--转载

    在注释KEGG的时候,一直用到kaas,具体kaas是个什么东东,简单的总结一下吧.     KEGG是由日本人搞的一个代谢图,收录基因和基因组的数据库,数据库可以分为 3大部分,基因数据库, 化学分 ...

  4. “static”引发的一个错误

    昨天晚上,舍友发来一个程序,先把代码贴上:  #include<stdio.h>#define N 20short bufferA[N]={1,2,3,4,5,6,7,8,9,10,11, ...

  5. Codeforces Round #267 (Div. 2)

    A #include <iostream> #include<cstdio> #include<cstring> #include<algorithm> ...

  6. 参考__JS

    教程 jQuery选择器总结 日期和时间 Bootstrap日期和时间表单组件 图表 morrisHighcharts 垂直滚动 fsvs 水平滚动 swiper 倒计时 countdownjs 全屏 ...

  7. 参考__CSS参考

    库 CsshakeAnimate.css

  8. Selenium:元素等待的4种方法

    1.使用Thread.sleep(),这是最笨的方法,但有时候也能用到而且很实用. 2.隐示等待,隐性等待是指当要查找元素,而这个元素没有马上出现时,告诉WebDriver查询Dom一定时间.默认值是 ...

  9. svn 版本控制

    首先来下载和搭建SVN服务器. Subversion已经迁移到apache网站上了,下载地址: http://subversion.apache.org/packages.html windows操作 ...

  10. 【腾讯云的1001种玩法】在腾讯云上创建您的SQL Cluster(5)

    版权声明:本文由李斯达 原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/97264001482830465 来源:腾云阁 h ...