在版本控制过程中需要同时推进多个任务,此时可以为每个任务创建单独分支即开一个一模一样的副本
,最终分支开发完后再合并到主分支提高开发效率
(分支底层其实也是指针的引用)
每一个分支都对应工作区和暂存区以及本地库(都需要添加暂存和提交本地)
, 各个分支相互独立互不干扰分支和文件版本的概念: 一个分支对应多个文件版本
,默认指向最后更新的那个文件版本
在项目目录下我们只能看到当前分支的内容
使用git init
命令创建本地仓库时默认会创建一个master分支
,其他分支可以围绕主分支进行开发
常用命令
命令 | 功能 |
---|---|
git branch | 列出本地的所有分支的简略信息 |
git branch -r | 列出所有的远程分支 |
git branch -a | 列出所有的本地分支和远程分支 |
git branch [branch-name] | 创建分支,分支的内容是基于当前分支复制的,包括文件版本信息 |
git checkout [branch-name] | 切换分支要求分支必须存在 当前分支上的内容必须先提交到本地库才能切换到其他分支 |
git checkout [-b] [branch-name] | 切换分支,如果分支不存在直接创建 |
git push [short-Name] [branch-name] | 推送资源至远程仓库的某个分支 |
git merge [branch-name] | 合并某个分支的资源到当前分支 |
git branch -d [branch-name] | 删除某个分支,会做检查对于还没有合并的分支可能无法删除删除分支时不能删除当前分支,只能删除其他分支 |
git branch -D [branch-name] | 强制删除分支 |
git push [short-Name] –d [branch-name] | 删除远程仓库中的某个分支 |
git branch -v(可省略)
: -v表示查看本地所有分支的详细信息,*
代表当前所在的分支
#查看本地所有分支的详细信息
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch -v
#当前分支是mater分支的my first版本
* master 087a1a7 my first commit
#查看本地所有分支的简略信息
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch
* master
git branch 分支名
: 创建分支, 分支的内容是基于当前分支复制的(包括指向的文件版本)
,创建后如果再修改主分支的内容也不会影响子分支
git branch -d/-D 分支名
: 删除分支,-d表示删除
时需要做各种检查,当删除没有合并的分支时会出现删除不了的情况
,-D表示强制删除
不做检查
#在当前分支的基础上创建hot-fix分支
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch hot-fix
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git branch -v
hot-fix 087a1a7 my first commit
* master 087a1a7 my first commit
git checkout 分支名
: 切换分支,当前分支上的内容必须先提交到本地库才能切换到其他分支
git checkout -b 分支名
: 切换分支,如果分支不存在则直接创建,创建的分支的内容是基于当前分支复制的
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git checkout hot-fix
Switched to branch 'hot-fix'
#发现当先分支已由master改为hot-fix
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
#查看hot-fix分支上的文件内容发现与master分支上的内容相同
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ cat hello.txt
hello git! hello atguigu!
#在hot-fix分支上同样需要进行文件的修改-->提交文件到暂存区-->提交到本地库-->查看版本的信息(不会影响到主分支的内容)
master,hot-fix
其实都是指向具体版本记录的指针,当前所在的分支其实是由HEAD决定的,所以创建分支的本质就是多创建一个指针
HEAD如果指向master
: 那么我们现在就在master分支上 , master分支指向具体的版本HEAD如果指向hotfix
: 那么我们现在就在hotfix分支上, hotfix分支也指向具体的版本每个分支都是独立的副本(都有各自的文件),修改创建的分支内容是不会影响主分支的内容
#在hot-fix分支上做修改
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ vim hello.txt
hello git! hello atguigu! hot-fix test
#添加暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ git add hello.txt
#提交本地库
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ git commit -m "hot-fix commit" hello.txt
#切换到mster分支
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ git checkout master
#master分支上还是第一次提交的版本内容
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ cat hello.txt
hello git! hello atguigu!
git merge 分支名
: 将指定分支合并到当前分支,如在master分支
执行合并命令,表示将其他分支上的资源合并到主分支,合并分支时会有提示输入wq可退出
#在maste分支上做修改
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ vim hello.txt
hello git! hello atguigu! master test
#添加暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git add hello.txt
#提交本地库
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git commit -m "master test" hello.txt
[master f363b4c] master test commit
1 file changed, 1 insertion(+), 1 deletion(-)
#再次修改在hot-fix分支上做修改
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (hot-fix)
$ vim hello.txt
hello git! hello atguigu! hot-fix test
hello git! hello atguigu! hot-fix test
#添加暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git add hello.txt
#提交本地库
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git commit -m "hot-fix test test" hello.txt
[master f363b4c] hot-fix test test commit
1 file changed, 1 insertion(+), 1 deletion(-)
#在master分支上合并hot-fix分支
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)
$ git merge hot-fix
Auto-merging hello.txt
CONFLICT (content): Merge conflict in hello.txt#合并时hello.txt文件有冲突
Automatic merge failed; fix conflicts and then commit the result
#冲突产生的表现:后面状态为 MERGING
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
#查看状态(检测到有文件有两处修改)
$ git status
On branch master
You have unmerged paths.
(fix conflicts and run "git commit")
(use "git merge --abort" to abort the merge)
Unmerged paths:
(use "git add ..." to mark resolution)
both modified: hello.txt
no changes added to commit (use "git add" and/or "git commit -a")
冲突合并
冲突合并: 合并分支时,如果有两个/多个分支
对同一个文件的同一个位置有两套完全不同的修改时,Git不知道使用哪一个分支修改的值, 此时就发生了冲突
方案
: 编辑有冲突的文件并删除特殊符号
,人为决定要留下的内容,将解决完冲突的文件加入暂存区,最后执行提交命令(不带文件名)提交到本地仓库#编写冲突的文件
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
$ vim hello.txt
<<<<<<< HEAD
当前分支的冲突代码
=======
合并过来分支的冲突代码
>>>>>>> hot-fix
#添加到暂存区
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
$ git add hello.txt
#提交本地库(此时使用git commit命令时不能带文件名)
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master|MERGING)
$ git commit -m "merge hot-fix"
[master 69ff88d] merge hot-fix
#发现后面MERGING消失,变为正常
Layne@LAPTOP-Layne MINGW64 /d/Git-Space/SH0720 (master)