首先从远端版本库clone下来一个全新的库:

git clone username@xxx:/xxx/xxx.git

此时clone下来的,只是master分支,没有其他分支。

查看分支:

git branch  #查看本地分支
git branch -r #查看远端分支
git branch -a #查看所有分支,包括本地和远程的

分支名前面有 * 的,就是当前所在分支。分支名型如remote/origin/xxx的,就是远端分支。

创建本地分支:

git branch <user_branch_name>  #在本地创建一个新分支
git checkout -b <user_branch_name> #在本地创建一个新分支,并且立即切换到这个分支(第一种方式只是创建了一个分支,并没有切换)

下面是使用 git checkout -b dev 创建的 dev 分支,会提示说已切换至新的分支 dev:

再次使用 git branch 查看分支,会发现本地有两个分支。其中dev分支前有个 *,说明当前分支是dev:

切换本地分支:

一个版本库可能有多个分支,例如现在有主分支master,有开发分支dev,那么从dev分支切换至master分支如下:

git checkout master  #从dev分支,切换到master分支

如上提示,已经切换至master分了。

此时再使用git branch查看分支情况,可以看到master前面有个 * ,说明已经切换到master了:

其实命令行提示尾部括号中的名字,就是当前所在分支:

可以看到,最后面的括号中的master,表明了当前所在分支。

合并本地分支:

合并分支命令:git merge 的工作流程是:将指定分支,合并至当前分支。

例如需要将 dev 开发分支,合并到 master 主分支上,需要如下两步操作:

1.切换到主分支

2.将dev合并至master

git checkout master  #切换到master分支
git merge dev #将dev分支合并至master分支

例如目前有两个分支,一个master分支,一个是dev分支。

这时新建了一个文件a.txt,在dev分支上完成git add 、 git commit两步操作,这表明,a.txt是属于dev分支的,切换到master分支时是看不到a.txt的。

这时切换到master分支,将dev分支合并至master,就会把dev的代码加入到master中。master也就可以看到a.txt了。

删除本地分支:

一个分支使用完了,可以删除掉。例如这个分支就是为了修复某一个bug的,bug修好了,新代码合并至master之后,这个分支就可以删除了。

git branch -d <branch_name>  #删除本地branch_name分支

另外:删除当前所在分支是不行的,会提示删除失败。

推送本地分支到远端:

#下面local_branch_name用来指明要推送本地哪个分支,remote_branch_name用来指明远端接收这个分支后叫什么。
git push origin [local_branch_name]:<remote_branch_name> #如果希望推送当前分支,那么local_branch_name:可以省略
git push origin remote_branch_name #另外本地分支名与远端分支名最好保持一致

其实只有master一个分支时做推送操作的命令中 git push origin master,最后这个master其实就是远端的master分支名,master其实也是一个分支,git要求版本库中必须至少要有一个分支,默认叫master。

删除远端分支:

删除远端分支有两种方式:

1.直接branch命令删除远端:

git branch -r -d <remote_branch_name>  #-r表示操作的是远端  -d表示执行删除操作

2.通过推送一个空的分支到远端,用空分支覆盖掉远端分支,从而删除这个远端分支:

git push origin :<remote_branch_name>  #注意,origin后面有一个 空格,以及一个冒号,这是必不可少的

3.删除已被删除的远程分支所对应的本地分支:

一个远程分支被删除了,可是本地还存在其对应的分支引用,可以这样删除:

git fetch -p

 拉取远程分支:

1.直接拉取某一分支:

git checkout -t <remote_branch_name> #-t 意为 track,即跟踪一个远程分支

2.在初次clone时直接clone某一分支(默认是clone下来主分支master):

git clone <repository> -b <branch_name>

Git分支管理的基本操作的更多相关文章

  1. GIT分支管理模型

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

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

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

  3. Git 分支管理详解

    大纲: 1.前言 2.创建分支 3.切换分支 4.合并分支(快速合并) 5.删除分支 6.分支合并冲突 7.合并分支(普通合并) 8.分支管理策略 9.团队多人开发协作 10.总结 注,测试机 Cen ...

  4. Git分支管理[三]

    标签(linux): git 笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 git分支管理命令 git branch #创建分支 git branch -v # ...

  5. Git—分支管理

    Git—分支管理 分支学习:branch称为分支,默认仅有一个名为master的分支.一般开发新功能流程为:开发新功能时会在分支dev上进行,开发完毕后再合并到master分支. branch相关常用 ...

  6. [转载]理解 Git 分支管理最佳实践

    原文 理解 Git 分支管理最佳实践 Git 分支有哪些 在进行分支管理讲解之前,我们先来对分支进行一个简单的分类,并明确每一类分支的用途. 分支分类 根据生命周期区分 主分支:master,deve ...

  7. 02: git分支管理

    目录:GIT其他篇 01: git & github 02: git分支管理 目录: 1.1 Git常用命令 1.2 主要分支(保护分支) 1.3 特性分支:feature (开发分支合并到d ...

  8. git 分支管理——多人协作

    git 分支管理--多人协作 一般一个项目有一个master主分支,还有一个develop开发分支.主要是在develop分支上协作开发,然后merge合并到master主分支上. 当从远程仓库克隆时 ...

  9. Git分支管理及合并

    Git分支管理   建立分支 git branch [name]   切换到分支 git checkout [name]   查看有哪些分支 git branch   比较分支 git diff [b ...

随机推荐

  1. DataNavigator之分页

    前言 做客户端也有两个月了,先前做列表都没有分页,可能考虑数据也不是很多,昨天做了一个页面,考虑到了数据的问题,所以改为分页查询.因为也是第一次用dev,用哪个控件分页呢,还是要去搜一下,得出的事Da ...

  2. 我们都忽略了Html5的力量,如果只看成一种技术就大错特错了!

    第一部分:Html5市场的力量 我们太忽略Html5的市场力量了.如果你把Html5当作一种技术,就大错特错了!忘掉你的产品,忘掉你的技术,想想移动时代的信息传播和消费场景.作为2B,我们实在是没有重 ...

  3. JQuery 绑定事件时传递参数的实现方法

    如题,比如我想在$(":text").bind("keyup",funcionName);将当前的文本框作为参数传递给 functionName所代表的函数,应 ...

  4. php 开启缓冲,页面纯静态化

    服务器默认不开启php缓冲区 两种方法开启 1.php.ini out_put_buffer = on 2.ob_start(); 页面纯静态化 file_put_contents()写文件 ob_s ...

  5. /dev/null 2>&1 解释(转)

    cmd >a 2>a 和 cmd >a 2>&1 为什么不同? cmd >a 2>a :stdout和stderr都直接送往文件 a ,a文件会被打开两遍, ...

  6. Python设计模式——代理模式(Proxy)

    书中的例子是:男A喜欢女A,但是不敢向其表白,所以委托男B为代理,代他送礼物给女A,实现这个需求的重点是,男A和女A是不互相直接接触的,都是通过代理男B,实现间接接触. #encoding=utf-8 ...

  7. Ubuntu 下部署asp.net运行环境

    在Ubuntu下部署asp.net运行环境,网上教程很多,基本都是编译Mono源码,然后安装jexus.但是可能是我最近RP不太好,编译Mono源码一直都是失败,无奈之下只好找另外的方法安装了. 网上 ...

  8. YARN加载本地库抛出Unable to load native-hadoop library解决办法

    YARN加载本地库抛出Unable to load native-hadoop library解决办法 用官方的Hadoop 2.1.0-beta安装后,每次hadoop命令进去都会抛出这样一个War ...

  9. [转载]C#图片格式(JPG,BMP,PNG,GIF)等转换为ICO图标

    using System; using System.Drawing; using System.Windows.Forms; using System.IO; namespace ICOTest { ...

  10. hdu 4268

    set的利用: #include<cstdio> #include<set> #include<algorithm> #define maxn 100009 usi ...