【Git】3. Git重要特性-分支操作,合并冲突详解

简介: 【Git】3. Git重要特性-分支操作,合并冲突详解

一、分支介绍


在版本控制过程当中,有时候需要同时推进多个任务,这样的话,就可以给每个任务创建单独的分支。


有了分支之后,对应的开发人员就可以把自己的工作从主线上分离出来,在做自己分支开发的时候,不会影响到主线分支的运行。


1268169-20210507231000811-120874177.png


如图所示:


  1. 要开发个新功能,加个蓝色背景。那么从master上建一个分支feature-blue,开发完后,合回到master。
  2. 同时另外一个新功能也要做,给系统加个小游戏。同样上建一个分支feature-game进行开发。
  3. 发现feature-blue上有个bug,那么再从master上建一个热修复分支hot-fix进行bug修改,完事后合到master。

所以,在众多分支并行开发的时候,master上的代码是正常在服务器上运行的,不会被影响。


故使用分支有如下优点:


  • 同时并行推进多个功能开发,提高开发效率。
  • 各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支造成影响。失败的分支可以删除掉重新开始即可。


二、分支操作


1. 查看分支


git branch -v


可以查看当前本地库有多少分支,其中*表示当前所在的分支。


1268169-20210507232400431-510429677.png


2. 创建分支


git branch 分支名


创建完成后,再次查看分支,就可以看到新建的分支hot-fix


1268169-20210507232637355-1414621157.png


3. 切换分支


当前所在还是master分支,我不想动master分支的内容,希望在hot-fix分支上进行修改,那么现在切换到目标分支。


git checkout 分支名


1268169-20210507233133754-621681920.png


已经切换成功。


现在我可以在hot-fix分支下进行文件内容的修改了,我改动hello.txt的第一行内容。

然后git add hello.txtgit commit -m "hot-fix first commit" hello.txt


1268169-20210507233624800-379792638.png


cat hello.txt可以查看文本内容,在git里 linux命令通用。


4. 合并分支


正常合并


hot-fix修改完内容提交之后,现在切换回master分支,并且查看文件内容,发现还是原来的样子,没有受到影响。


1268169-20210507234143221-1202032255.png


现在我要把hot-fix上的内容合并到master上:


git merge 分支名


注意,这里是把命令行后输入的分支 合并到 当前所在分支,所以我先要切回到master上,才可以把hot-fix合过来。


1268169-20210507234524324-704479991.png


合并完成,查看master分支上的文件内容,发现hot-fix上新增的内容已经合并了过来。


1268169-20210507234629243-1603524777.png


冲突合并


合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改,这就产生了冲突,这也是团队协助中最常见的场景之一了。


此时,git无法决定使用哪一个,所以必须人为的决定新代码的内容。


现在来造成一个冲突的场景:


  1. master分支,在hello.txt的最后一行末尾,增加新内容-"master test"。
  2. 切换到hot-fix分支,在hello.txt的最后一行末尾,增加新内容-"hot-fix test"。
  3. 切换到master分支,合并hot-fix分支。


1268169-20210507235653899-1978382653.png


提示自动合并失败,因为在hello.txt里面产生了冲突,此时查看git status,也可以看到提示。


1268169-20210507235927525-564627495.png


OK,git处理不了,只能我们亲自出马了。此时可以打开文件vim hello.txt,会发现在文件里有冲突的提示。


1268169-20210508000217234-271453895.png


有3个提示:


  • <<<<<<< HEAD,表示当前分支。
  • =======,相当于分界线,等号与上面的HEAD之间,是当前分支的代码。等号与下面的 hot-fix,是要合并过来的代码。
  • >>>>>>> hot-fix,要合并过来的分支。


现在我手动处理,希望2个分支的代码都保留,那么我留下这2行代码,把其余的提示信息去掉即可。


1268169-20210508000805842-155204114.png


完成后进行git add hello.txt


注意,在接下来的git commit操作中,就不要带文件名了,否则会报错,如下:


1268169-20210508001121304-1014806169.png


git此时还是不知道用哪个分支的hello.txt,所以提交的时候不要带文件名了。


1268169-20210508001235842-2073688158.png


可以看到合并成功,接着查看下文件内容,cat hello.txt,结果如愿以偿。


1268169-20210508001408410-313337350.png


注意,这里合并时候的修改,也只是改了master分支的文件内容,hot-fix分支是不受影响的,可以切到hot-fix查看文件内容便知。


1268169-20210508001625265-2017610761.png


分支原理


跟版本切换一样,分支切换的底层同样是指针。


上面的2个分支masterhot-fix,其实都是指向具体版本记录的指针。而当前所在的分支,其实是有HEAD决定的,HEAD指向哪个分支,现在就在那个分支上。


所以,创建分支的本质就是多创建一个指针,故切换分支的本质就是移动HEAD指针。


接下来是git的团队协助相关内容。

相关文章
|
1天前
|
开发工具 git
图解Git——分支的新建与合并《Pro Git》
在Git开发中,新建与合并分支是常见的操作。以实际开发为例:为实现新需求创建分支`iss53`进行开发;遇紧急Bug时,切换至线上分支创建`hotfix`修复并合并回线上分支,再切换回`iss53`继续工作。完成`iss53`后,切换到`master`合并。若出现冲突,使用`git status`查看,手动编辑解决冲突后标记为已解决并提交。图形化工具如`git mergetool`也可辅助解决冲突。
27 9
|
1天前
|
开发工具 git 开发者
图解Git——分支简介《Pro Git》
Git 分支是其核心特性之一,允许开发者从主开发线分离工作,避免干扰主线。传统版本控制系统创建分支效率低,而Git的分支创建和切换非常轻量高效。
25 9
|
1天前
|
存储 项目管理 开发工具
图解Git——分支开发工作流《Pro Git》
分支开发工作流利用Git的分支功能,支持灵活的项目管理。长期分支如`master`和`develop`分别保存稳定和开发中的代码;短期主题分支用于开发单一特性或修复问题,完成后合并到主分支。此模式确保代码稳定性,支持并行开发、便于审查和灵活调整。建议维护明确的长期分支,保持主题分支短小精悍,并定期清理无用分支。配置上可保护关键分支,遵循命名规范。
18 7
|
1天前
|
存储 缓存 Java
图解Git——远程分支《Pro Git》
远程分支是 Git 中用于管理分布式协作的关键概念。远程引用指向远程仓库中的分支和标签,常用 `git ls-remote` 或 `git remote show` 查看。日常开发中,通常使用远程跟踪分支(如 `origin/main`)与远程分支交互,简化远程仓库状态的管理和使用。远程跟踪分支记录远程分支的状态,但本身只读。
17 6
|
3月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
162 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
3月前
|
开发工具 git 开发者
关于git 解决分支冲突问题(具体操作,包含截图,教你一步一步解决冲突问题)
本文通过具体操作和截图,详细讲解了如何在Git中解决分支冲突问题,包括如何识别冲突、手动解决冲突代码、提交合并后的代码,以及推送到远程分支。
739 3
关于git 解决分支冲突问题(具体操作,包含截图,教你一步一步解决冲突问题)
|
4月前
|
缓存 开发工具 git
Git创建分支以及合并分支
在Git中,创建分支使用`git branch [branch_name]`,切换分支使用`git checkout [branch_name]`。修改文件后,通过`git add [file]`添加到暂存区,然后`git commit`提交到本地仓库。如果是新建分支的第一次推送,使用`git push origin [branch_name]`推送到远程仓库,之后可以简化为`git push`。合并分支时,使用`git merge [branch_name]`将指定分支的更改合并到当前分支。
120 2
Git创建分支以及合并分支
|
3月前
|
开发工具 git
Git分支使用总结
Git分支使用总结
60 1
|
4月前
|
测试技术 开发工具 git
掌握 Git 分支策略:提升你的版本控制技能
在现代软件开发中,版本控制至关重要,Git 作为最流行的分布式版本控制系统,其分支管理策略对于高效协作和代码维护尤为重要。本文介绍了几种常用的 Git 分支策略,包括主线开发模型、功能分支模型、Gitflow 工作流和 Forking 工作流,并探讨了如何根据项目需求选择合适的分支模型。通过保持 `master` 分支稳定、及时合并清理分支、使用命名规范、利用 Pull Request 进行代码审查及自动化测试等最佳实践,可以显著提升团队协作效率和软件质量。掌握这些策略将帮助开发者更好地管理代码库,加快开发流程。
|
4月前
|
存储 Linux 开发工具
Git基础命令,分支,标签的使用【快速入门Git】
本文详细介绍了Git版本控制系统的基础概念和常用命令,包括工作区、暂存区和版本库的区别,文件状态的变化,以及如何进行文件的添加、提交、查看状态、重命名、删除、查看提交历史、远程仓库操作和分支管理,还涉及了Git标签的创建和删除,旨在帮助读者快速入门Git。
Git基础命令,分支,标签的使用【快速入门Git】

相关实验场景

更多