【Git】本地分支

转载:https://www.cnblogs.com/yangchongxing/p/10221382.html

目录

=================================

1、查看分支列表

2、切换分支

3、删除分支

4、创建分支

5、合并分支

6、跟踪分支

7、创建跟踪分支

=================================

1、查看分支列表

本地分支

$ git branch
dev
* master

分支前的 * 字符:它代表现在所处的分支(也就是说,当前 HEAD 指针所指向的分支)。

远程分支

$ git branch -r
origin/master
origin/nb

所有分支(本地和远程)

$ git branch -a
* master
nb
remotes/origin/master
remotes/origin/nb

分支前的 * 字符:它代表现在所处的分支(也就是说,当前 HEAD 指针所指向的分支)。

分支名及校验和

$ git branch -v

已合并分支

$ git branch --merged
dev
* master

在这个列表中分支名字前没有 * 号的分支通常可以使用 git branch -d 删除掉;你已经将它们的工作整合到了另一个分支,所以并不会失去任何东西。

未合并分支

$ git branch --no-merged
issue-

还未合并的尝试使用 git branch -d 命令删除它时会失败:

$ git branch -d issue-
error: The branch 'issue-1' is not fully merged.
If you are sure you want to delete it, run 'git branch -D issue-1'.

如果真的想要删除分支并丢掉那些工作,如同帮助信息里所指出的,可以使用 -D 选项强制删除它。

$ git branch -D issue-
Deleted branch issue- (was 0734b29).

2、切换分支

$ git checkout dev

注意:分支切换会改变你工作目录中的文件

3、删除分支

$ git branch -d dev
$ git branch --delete dev

没有合并时无法删除,强制删除

$ git branch -d -f dev
$ git branch --delete --force dev

简写,Shortcut for --delete --force.

$ git branch -D dev

强制删除,没有合并也会删除,谨慎使用

4、创建分支

4.1、新建分支并留在当前分支

$ git branch dev

4.2、新建分支同时切换到新分支

$ git checkout -b dev

4.3、使用服务器分支,新建分支同时切换到新分支

$ git fetch origin 或者 git fetch
$ git checkout -b server_branch origin/server_branch

注意:git fetch 命令必须执行。执行完成后,你将会拥有那个远程仓库中所有分支的引用,可以随时合并或查看。

查看分支对象

$ git log --oneline --decorate

参数:--oneline,显示在一行

参数 --decorate,查看各个分支当前所指的对象

5、合并分支

5.1、快进合并

例:把dev合并到master,注意合并前其他分支都提交完了。首先切换到master分支,然后使用 git merge 命令把dev分支合并到主分支上

$ git checkout master
$ git merge dev
Updating 9525a36..1bfbd70
Fast-forward
book.java | +
file changed, insertion(+)

在合并的时候,你应该注意到了"快进(fast-forward)"这个词。 由于当前 master 分支所指向的提交是你当前dev提交的直接上游,所以 Git 只是简单的将指针向前移动。 换句话说,当你试图合并两个分支时,如果顺着一个分支走下去能够到达另一个分支,那么 Git 在合并两者的时候,只会简单的将指针向前推进(指针右移),因为这种情况下的合并操作没有需要解决的分歧——这就叫做 “快进(fast-forward)”。

5.2、典型三个快照的合并

$ git checkout master
$ git merge dev
Merge made by the 'recursive' strategy.
home.html | +
index.html | +
files changed, insertions(+)
create mode home.html
create mode index.html

和之前将分支指针向前推进所不同的是,Git 将此次三方合并的结果做了一个新的快照并且自动创建一个新的提交指向它。 这个被称作一次合并提交,它的特别之处在于他有不止一个父提交。

需要指出的是,Git 会自行决定选取哪一个提交作为最优的共同祖先,并以此作为合并的基础。 Git 的这个优势使其在合并操作上比其他系统要简单很多。

5.3、遇到冲突的合并

例:
master 分支编辑index.html内容如下,然后提交
index.html master
dev 分支编辑index.html内容如下,然后提交
index.html dev
合并

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

显示有冲突,编辑冲突文件

$ vim index.html
<<<<<<< HEAD
index.html master
=======
index.html dev
>>>>>>> dev

冲突内容使用<<<<<<<,=======,>>>>>>>完全隔开了。上半部分是HEAD也就是master分支,下半部分是dev分支。

$ vim index.html

手动解决冲突部分如下,然后 git add index.html

index.html master

然后提交 git commit -m '注解'

6、跟踪分支

6.1、查看分支跟踪

$ git branch -vv

6.2、设置分支跟踪

格式:二选一

git branch -u 远程库名/远程分支名

git branch --set-upstream-to=远程库名/远程分支名

$ git branch -u origin/dev
$ git branch --set-upstream-to=origin/dev

远程分支名必须存在,否则error: the requested upstream branch 'origin/b2' does not exist

6.3、取消分支跟踪

$ git branch --unset-upstream 本地分支名

7、创建跟踪分支

新建一个分支并且和远程分支建立跟踪关系

格式:二选一

git branch -t 本地分支名 远程库名/远程分支名
git branch --track 本地分支名 远程库名/远程分支名

$ git branch -t dev origin/dev
$ git branch --track dev origin/dev

【Git】本地分支的更多相关文章

  1. git 本地分支与远程分支

    github上已经有master分支 和dev分支 在本地 git checkout -b dev 新建并切换到本地dev分支 git pull origin dev 本地分支与远程分支相关联 在本地 ...

  2. git 本地分支与远程分支关联的一种方法

    github上已经有master分支 和dev分支 在本地 git checkout -b dev 新建并切换到本地dev分支 git pull origin dev 本地分支与远程分支相关联 在本地 ...

  3. Git本地分支版本号过低导致的push错误 error: failed to push some refs to ... 及兴许amend

    今天在用git的时候遇到了一个问题.在想远程分支push的时候,出现了以下的错误: ! [remote rejected] master -> refs/for/master (change 1 ...

  4. git本地分支与远程分支

    github上已经有master分支 和dev分支 在本地 git checkout -b dev 新建并切换到本地dev分支 git pull origin dev 本地分支与远程分支相关联 在本地 ...

  5. git 本地分支和远程分支改名字

    1.将本地分支进行改名: git branch -m old_branch new_branch 2.将本地分支的远程分支删除: git push origin :old_branch 3.将改名后的 ...

  6. Git本地分支和远程分支关联

    转载:https://blog.csdn.net/cherishhere/article/details/52606884 转载:https://blog.zengrong.net/post/1746 ...

  7. 怎么删除git本地分支以及Bitbucket的远程分支?

    1. 如果分支只是本地分支,则可以使用 -d (如果分支已合并),例如 git branch -d <branch name>如果分支包含不计划合并的代码,请改用 -D (即使有没有mer ...

  8. git本地分支和远程分支改名

    #1 将本地分支进行改名 git branch -m old_branch new_branch #2 将远程分支的老分支删除 git push origin :old_branch #3 将改名后的 ...

  9. git本地分支关联远程分支

    问题描述: 从远程master克隆下来以后, 在本地创建wf_dev分支, 此时执行git pull 操作出现图中问题. 这是因为:本地的wf_dev分支还没有和远程的wf_dev进行关联. 执行:  ...

  10. git本地分支重命名

    1. 本地分支重命名 git branch -m oldbranchname newbranchname 2. 远程分支重命名 (假设本地分支和远程对应分支名称相同) a. 重命名远程分支对应的本地分 ...

随机推荐

  1. SpringBoot让你的Bean动起来(自定义参数解析HandlerMethodArgumentResolver)

    SpringBoot让你的Bean动起来(自定义参数解析HandlerMethodArgumentResolver) 简介 我们 Controller 用到的一些 Bean 需要通过一定的方式去获取的 ...

  2. boost.asio新框架的设计概念总结

    1.66版本,boost.asio库重新设计了框架,目前最新版为1.71.读了几天代码后,对框架中相关概念总结.因为是泛型编程的库,所以分析的概念层的设计. 可通过boost官方文档,strand的1 ...

  3. gcc在x64体系中如何传递参数,linux,mac,iOS适用

    上一篇介绍了vc(windows)平台在x64体系当中,c函数的传参方式.本篇将要介绍gcc(类linux,mac)平台在x64中,c函数是如何传参的.为节约时间和篇幅,首先来定义一个有十个参数的函数 ...

  4. PHP安全之道学习笔记1:PHP项目安全设置

    在全球范围来看,超过了80%的网站是使用php进行搭建的,由于脚本语言和早期版本设计的诸多原因,php项目存在不少安全隐患.从配置选项来看,可以做如下的优化. 1.屏蔽PHP错误输出. 在/etc/p ...

  5. dom4j的测试例子和源码详解(重点对比和DOM、SAX的区别)

    目录 简介 DOM.SAX.JAXP和DOM4J xerces解释器 SAX DOM JAXP DOM解析器 获取SAX解析器 DOM4j 项目环境 工程环境 创建项目 引入依赖 使用例子--生成xm ...

  6. web 开发常用字符串表达式匹配

    记录一下 web 开发中常用的一些字符串模式,这是我遇到的一些,后面如果还有的话,欢迎大神提出,会继续更新. 正则表达式 这个主要用在前端的验证,nginx 路径匹配,shell 脚本文本处理,后端感 ...

  7. 性能测试:深入理解线程数,并发量,TPS,看这一篇就够了

    并发数,线程数,吞吐量,每秒事务数(TPS)都是性能测试领域非常关键的数据和指标. 那么他们之间究竟是怎样的一个对应关系和内在联系? 测试时,我们经常容易将线程数等同于表述为并发数,这一表述正确吗? ...

  8. 基于SDF渲染字体

    18号字体 18号字体放大15倍 基于sdf渲染字体放大15倍 相比常规的渲染方式,基于SDF渲染文字可无限放大并保持清晰,几乎没有开销就可实现描边,发光,抗锯齿等效果.且它只需要很小的纹理缓存SDF ...

  9. logistic回归介绍以及原理分析

    1.什么是logistic回归? logistic回归虽然说是回归,但确是为了解决分类问题,是二分类任务的首选方法,简单来说,输出结果不是0就是1 举个简单的例子: 癌症检测:这种算法输入病理图片并且 ...

  10. React躬行记(15)——React Hooks

    Hook(钩子)是React v16.8新引入的特性,能以钩子的形式为函数组件附加类组件的状态.生命周期等特性.React的类组件有难以拆分.测试,状态逻辑分散,难以复用等问题,虽然可以通过渲染属性( ...