1、分支

(1)概念

每提交一次代码就会有一个记录,git把这些提交代码的时间点串联起来,就把他们变成了一条时间线,这条时间线就是一个分支。一般情况下,只有一条时间线,这个分支叫作主分支,即master分支。HEAD指针(指向当前的分支,默认指向master)严格来说是不指向提交的,而是指向master,master才是指向提交的,因此,HEAD指向的就是当前分支。GIT用master指向最新提交,HEAD指向master,就能确定当前分支以及当前分支的提交点。

git:分支管理(分支的创建、使用、合并、删除)_并行开发

 

 

2、创建分支

(1)切换与检出:

git:分支管理(分支的创建、使用、合并、删除)_git_02

 

 (2)新建一个分支:

git:分支管理(分支的创建、使用、合并、删除)_修改文件_03

 

 (3)查看分支:

git:分支管理(分支的创建、使用、合并、删除)_git_04

 

 

3、分支的使用

(1)切换到master分支:

创建一个文件,并提交到本地仓库:

git:分支管理(分支的创建、使用、合并、删除)_并行开发_05

 

(2)修改master分支的另一个文件:

git:分支管理(分支的创建、使用、合并、删除)_并行开发_06

 

 (3)切换到另一个分支:test1

切换前:

git:分支管理(分支的创建、使用、合并、删除)_分支合并_07

 

 切换后:

git:分支管理(分支的创建、使用、合并、删除)_右键_08

 

 切换到test1分支以后,在master分支创建的文件没有了。

git:分支管理(分支的创建、使用、合并、删除)_分支合并_09

 

 master在update.txt文件添加的内容也没有了。

(4)利用test1分支创建一个文件(test1.txt)并提交:

git:分支管理(分支的创建、使用、合并、删除)_修改文件_10

 

(5)在master分支添加过的文件内,切换到test1分之后继续修改(此时,切换到test1分之后,master分支修改的内容是看不到的):

git:分支管理(分支的创建、使用、合并、删除)_分支合并_11

 

 修改并提交。

(6)到目前为止两个分支master和test1是并行开发,互不干扰的:

master分支创建了master文件,并修改了update文件;test1分支创建了test1文件,并修改了update文件。

 

4、分支的合并(在上面master和test1两个分支的基础上进行)

(1)切换到master分支

(2)选择合并:

git:分支管理(分支的创建、使用、合并、删除)_git_12

 

 (3)选择从哪一个分支合并(这里是向master分支合并)

git:分支管理(分支的创建、使用、合并、删除)_修改文件_13

 

 (4)产生冲突,合并后的分支两个分支的文件都出现了:

git:分支管理(分支的创建、使用、合并、删除)_git_14

 

因为两个分支都对update文件进行了修改:

git:分支管理(分支的创建、使用、合并、删除)_右键_15

 

 手动修改文件后,选择解决冲突:

git:分支管理(分支的创建、使用、合并、删除)_修改文件_16

 

 

 (5)在master分支中提交。

 

5、删除分支

(1)选择切换检出:

git:分支管理(分支的创建、使用、合并、删除)_git_17

 

 (2)查看分支:

git:分支管理(分支的创建、使用、合并、删除)_分支合并_18

 

 (3)右键删除分支:

git:分支管理(分支的创建、使用、合并、删除)_并行开发_19

 

 (4)查看分支:

git:分支管理(分支的创建、使用、合并、删除)_右键_20

 

每个人都会有一段异常艰难的时光 。 生活的压力 , 工作的失意 , 学业的压力。 爱的惶惶不可终日。 挺过来的 ,人生就会豁然开朗。 挺不过来的 ,时间也会教你 ,怎么与它们握手言和 ,所以不必害怕的。 ——杨绛