一、分支
1、分支简单介绍
简单使用:
data:image/s3,"s3://crabby-images/7cd3b/7cd3bdb77eb25a95308bf7ada5f776ea4fc1840c" alt=""
可以将
git branch new_branch
和git checkout new_branch
两个命令合并成一个命令:git checkout -b new_branch
。这个命令的意思就是创建一个分支并且切换到这个分支上。
本地分支改名:git branch -m 原分支名 新分支名
2、合并分支merge
这个过程中,下一个版本会记录一个parent id
,这个parent id
就是前一个版本的commit id
。
data:image/s3,"s3://crabby-images/2b29b/2b29b0ff20a9ede3281976f7c01747bf968909da" alt=""
注意当我们在dev
中更改文件之后,一定要先add
和commit
,不然那样就会和master
内容同步了,我们需要的是在dev
中更改之后,在没有进行merge
之前,master
不会和dev
相同: 看下面的演示:
data:image/s3,"s3://crabby-images/d591e/d591eb333f7e2a3e932d6394bd2ae1643c44195d" alt=""
3、快进fast forward
HEAD的含义: (在git reset HEAD test.txt
中使用过)
- HEAD指向的是当前分支;
- master是指向提交(本质上只的是当前的提交);
即如下表示:
data:image/s3,"s3://crabby-images/bbecf/bbecf0075d800872890e148d6eb7e3b0976e7fce" alt=""
如果我们执行git checkout -b dev
,我们就会创建一个dev
分支并指向新的分支。
这是在master
分支的基础上,但是这个过程并不是像SVN
一样会拷贝一份,而是只是创建一个指针dev
,会和master
指向了同一个提交。但此时HEAD指向的是dev
(当前分支)。
data:image/s3,"s3://crabby-images/9e182/9e1827627863c16150a49da267300a5047c28fa6" alt=""
查看HEAD文件的内容:
data:image/s3,"s3://crabby-images/79835/79835548397000a1329ce8392a8c38b1c7ce0c13" alt=""
然后我在上图的基础上,如果我在dev
分支下进行了一次提交,图就会变成下面这样:
data:image/s3,"s3://crabby-images/ee0a7/ee0a71c35618738b4f0ee39ade431ae1468b071b" alt=""
此时master
指向第3次提交,而dev
已经指向了第四次提交。
接下来,如果我将dev
上面的修改合并到master
上面 (在master
中操作),上面的图就会变成下面这样:
data:image/s3,"s3://crabby-images/b3853/b38532c8c5d9199616944a9056dca979aef5be38" alt=""
这种情况不会有冲突存在。
实战演示:
data:image/s3,"s3://crabby-images/238c8/238c872ea63ef49883502cc030c13b14bdd3e186" alt=""
总结一下这种情况,就是直接从master
分支跳转到了最后的dev
修改的那个位置,相当于指针的跳转。
4、master和dev同时修改同一文件同一位置产生冲突
演示冲突:在master
中修改了test.txt
的第三行,在dev
中也修改了test.txt
中的第三行,于是合并的时候就会产生冲突:
data:image/s3,"s3://crabby-images/d22e9/d22e9df17feaf9cb93c71b1fa4d94f71baf1aa5e" alt=""
上面的过程就是如下图的过程:
data:image/s3,"s3://crabby-images/7f973/7f97353795383cd331c2139652f423ffcae92812" alt=""
注意箭头往回指是因为后一个提交里面包含一个
parent-id
指向前一个提交的commit-id
,前面已经说过。
注意观察master
分支中test.txt
文件的内容以及我们将解决这次冲突(即我们打算保存master
的修改而丢弃dev
的修改):
data:image/s3,"s3://crabby-images/a233e/a233ed0cd070c82c83d9d375f11e297be899c867" alt=""
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
的图解:
data:image/s3,"s3://crabby-images/93599/93599f0f3aea1b8e3337397cbae9dd9b157051c9" alt=""
我们先看使用fast-forward
模式下的: (即合并的时候commit-id
和另一个分支相同):
data:image/s3,"s3://crabby-images/1ed26/1ed269359c864118707facaf6fe86aafb1aae907" alt=""
再看不使用fast-forward
模式:
data:image/s3,"s3://crabby-images/4d6a0/4d6a00e235f769244835c96e7f72f3dc5837f178" alt=""
二、Git版本回退
Git的另外一个强大之处在于可以回退到之前的任意一个版本:
data:image/s3,"s3://crabby-images/340d5/340d5a835a6a54b0f31167e0cffae5ff2cb8add6" alt=""
主要看下面的命令:
-
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
查看自己的操作日志;
实战演示:
data:image/s3,"s3://crabby-images/50eca/50eca4e2ddda40e905ebcc4cc6e43e4556eabfae" alt=""
查看修改和提交日志:
data:image/s3,"s3://crabby-images/ff636/ff6369b2a0b418607fb6b2f7d7ec66f88f8a5524" alt=""
下面演示怎么回退:
data:image/s3,"s3://crabby-images/21462/2146278c8b2f911e0093d6e7efd8ce69a2a16387" alt=""
原文:Java架构笔记
免费Java高级资料需要自己领取,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并发分布式等教程,一共30G。
传送门:https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q
网友评论