Git分支和版本回退
一、分支
1、分支简单介绍
简单使用:

可以将
git branch new_branch和git checkout new_branch两个命令合并成一个命令:git checkout -b new_branch。这个命令的意思就是创建一个分支并且切换到这个分支上。
本地分支改名:git branch -m 原分支名 新分支名
2、合并分支merge
这个过程中,下一个版本会记录一个parent id,这个parent id就是前一个版本的commit id。

注意当我们在dev中更改文件之后,一定要先add和commit,不然那样就会和master内容同步了,我们需要的是在dev中更改之后,在没有进行merge之前,master不会和dev相同: 看下面的演示:

3、快进fast forward
HEAD的含义: (在git reset HEAD test.txt中使用过)
- HEAD指向的是当前分支;
- master是指向提交(本质上只的是当前的提交);
即如下表示:

如果我们执行git checkout -b dev,我们就会创建一个dev分支并指向新的分支。
这是在master分支的基础上,但是这个过程并不是像SVN一样会拷贝一份,而是只是创建一个指针dev,会和master指向了同一个提交。但此时HEAD指向的是dev(当前分支)。

查看HEAD文件的内容:

然后我在上图的基础上,如果我在dev分支下进行了一次提交,图就会变成下面这样:

此时master指向第3次提交,而dev已经指向了第四次提交。
接下来,如果我将dev上面的修改合并到master上面 (在master中操作),上面的图就会变成下面这样:

这种情况不会有冲突存在。
实战演示:

总结一下这种情况,就是直接从master分支跳转到了最后的dev修改的那个位置,相当于指针的跳转。
4、master和dev同时修改同一文件同一位置产生冲突
演示冲突:在master中修改了test.txt的第三行,在dev中也修改了test.txt中的第三行,于是合并的时候就会产生冲突:

上面的过程就是如下图的过程:

注意箭头往回指是因为后一个提交里面包含一个
parent-id指向前一个提交的commit-id,前面已经说过。
注意观察master分支中test.txt文件的内容以及我们将解决这次冲突(即我们打算保存master的修改而丢弃dev的修改):

5、深入fast-forward模式
也就是说在fast-forward模式下:
- 如果可能(合并时没有冲突),那么Git就会采用
fast-forward模式; - 在这种模式下,删除分支时会丢掉分支信息;
- 合并时加上
-- no-ff参数会禁用fast-forward模式,这样就会多出一个commit - id,也就是说在fast-forward模式下面merge不会多出一个commit-id;
git merge -- no-ff dev
- 查看日志更好的方式
git log --graph
关于fast-forward模式和非fast-forward模式下的少一次commit-id和多一次commid-id的图解:

我们先看使用fast-forward模式下的: (即合并的时候commit-id和另一个分支相同):

再看不使用fast-forward模式:

二、Git版本回退
Git的另外一个强大之处在于可以回退到之前的任意一个版本:

主要看下面的命令:
git reset --hard HEAD^, 往后回退1个版本;git reset --hard HEAD~3,往后回退3个版本;git reset --hard commit-id,直接回退到某个commit-id;(如果当前在靠前面,就可以通过git log查看);- 如果在后面,不能查看到前面的
git log 得到 commit-id怎么办呢?可以用git reflog查看自己的操作日志;
实战演示:

查看修改和提交日志:

下面演示怎么回退:

原文:Java架构笔记
免费Java高级资料需要自己领取,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并发分布式等教程,一共30G。
传送门:https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q
Git分支和版本回退的更多相关文章
- [原]git的使用(一)---建立本地仓库、add和commit、status和git diff、版本回退使用git reset
在window下已经安装了git的环境 1.建立本地仓库 mkdir test #建立test目录 cd test #进入目录 git init # ...
- Git使用:版本回退
在Git中,我们可以用 git log命令查看我们修改的历史记录 C:\Users\Administrator\Documents\GitHub\learngit [master]> git l ...
- Git新建分支,分支合并,版本回退详解
一.git基本命令 git拉取仓库代码 #拉取master代码 git clone git仓库地址 #拉取分支代码 git clone -b 分支名称 git仓库地址 2.git添加代码到本地仓库 g ...
- Git秘籍:在 Git 中进行版本回退
导读 在这篇文章中,你将学到如何查看项目中的历史版本,如何进行版本回退,以及如何创建 Git 分支以便你可以大胆尝试而不会出现问题.快来试试吧. 在你的 Git 项目的历史中,你的位置就像是摇滚专辑中 ...
- Git 系列(四):在 Git 中进行版本回退
在这篇文章中,你将学到如何查看项目中的历史版本,如何进行版本回退,以及如何创建 Git 分支以便你可以大胆尝试而不会出现问题. 在你的 Git 项目的历史中,你的位置就像是摇滚专辑中的一个片段,由一个 ...
- 记录一次Git远程仓库版本回退
操作过程: 首先查看远程仓库版本,如下图所见,最近一次提交为2018-03-19 22:16:25 第一步:使用git log命令查看历史提交记录,选择要回退的版本号,commit后面一串字符,这里我 ...
- 【Git学习笔记】初始化Git仓库和版本回退
学习地址 http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 什么是版本库呢?版本库又 ...
- git中的版本回退
git版本回退有两种情况,一种是从本地版本库中(head区)回退到某个版本,可以用命令 git reset --hard head^ 或git reset --hard head~x ,head指的是 ...
- Git教程之版本回退(4)
现在,我们已经学会了修改文件,然后把修改提交到Git版本库,现在再次修改readme.txt文件如下:
随机推荐
- 解决Vue调用springboot接口403跨域问题
最近在做一个前后端分离的项目, 前端用的是Vue后端使用的是springboot, 在项目整合的时候发现前端调用后端接口报错403跨域请求问题 前端跨域请求已解决, 那么问题就出在后端了, 找了一些资 ...
- USACO Apple Delivery
洛谷 P3003 [USACO10DEC]苹果交货Apple Delivery 洛谷传送门 JDOJ 2717: USACO 2010 Dec Silver 1.Apple Delivery JDOJ ...
- C++ vector初始化方式
C++的初始化方法很多,各种初始化方法有一些不同. (1): vector<int> ilist1; 默认初始化,vector为空, size为0,表明容器中没有元素,而且 capacit ...
- leetcode138. 复制带随机指针的链表
思路一:哈希 借助哈希保存节点信息. 代码 时间复杂度:O(n)空间复杂度:O(n) class Solution{ public: Node* copyRandomList(Node* head) ...
- hadoop 输入路径用正则表达式被默认处理为多个参数的问题
运行命令 hadoop jar wordcount.jar com.WordCount /inpath/*{beijing,shanghai,guangzhou}* /outpath/ ...
- public.js
//通过id名称获取元素对象 function getid(idName){ return document.getElementById(idName); } //随机获取min-max的随机整数 ...
- luogu P1084疫情控制 二分
链接 loj luogu太水不要去了. 思路 二分. 每个军队在一定的时间内越往上越好. 注意一个军队可以跨过1去帮别的. 把能到1脚下的点都存下来特判. 有一种情况是这个子树内只有一个军队,但这个军 ...
- NLP之CRF应用篇(序列标注任务)
1.CRF++的详细解析 完成的是学习和解码的过程:训练即为学习的过程,预测即为解码的过程. 模板的解析: 具体参考hanlp提供的: http://www.hankcs.com/nlp/the-cr ...
- Linux性能优化实战学习笔记:第二十八讲
一.案例环境描述 1.环境准备 2CPU,4GB内存 预先安装docker sysstat工具 apt install docker.io sysstat nake git 案例总共由三个容器组成: ...
- java web开发入门十(idea创建maven SSM项目)基于intellig idea
一.搭建项目骨架 二.配置pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xm ...