4、Git之分支操作

news/2024/11/15 10:40:12/文章来源:https://www.cnblogs.com/Javaer1995/p/17959051

4.1、分支的概述

在版本控制过程中,当需要同时推进多个任务时,可以为每个任务创建的单独分支。

虽然分支的底层实现是指针的引用,但是初学阶段可以将分支简单理解为副本,一个分支就是一个单独的副本。

使用分支,意味着从原来的主干上分离开,在分支上做的任何改动,在合并前都不会影响到主干。

image

4.2、分支的优点

可以并行推进多个功能模块的开发,提高开发效率。

各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。

4.3、分支的操作

4.3.1、命令速查表

命令 作用
git branch 分支名 创建分支
git branch -v 查看分支
git checkout 分支名 切换分支
git merge 分支名 把指定的分支合并到当前分支上
git branch -d 分支名 删除分支

4.3.2、查看分支

image

git branch -v

本示例的分支信息说明:

  • master :分支名称

  • bcd91c3 :分支当前指向的版本号

  • 第二次提交:分支当前指向的版本的日志信息

4.3.3、创建分支

image

git branch 分支名

本示例根据 master (主干)分支创建了 user 分支;刚创建的 user 分支除了分支名之外,其他都和 master (主干)分支是一样的。

4.3.4、切换分支

image

git checkout user

切换分支成功后,命令行会提示目前是在 user 分支上;查看分支时,user 分支也被用星号高亮标记。

4.3.5、修改分支

4.3.5.1、在新分支上新增文件

image

4.3.5.2、将新分支的改动提交到本地库

image

4.3.5.3、切换回主干分支

image

切换回 master 主干分支后,可以发现工作区没有在 user 分支时新增的文件,即 master 主干分支没有受到 user 分支的影响。

4.3.6、合并分支

image

git merge user

如上图所示,合并 user 分支到 master 分支后, master 分支多了一个在 user 分支新增的文件

image

如上图所示,合并分支后,user 分支和 master 分支的版本号和提交日志信息都是一致的。

4.3.7、模拟冲突

4.3.7.1、user分支操作

image

切换到 user 分支,修改 hello.txt 文件,并提交到本地库。

4.3.7.2、master分支操作

image

切换到 master 分支,修改 hello.txt 文件,并提交到本地库。

4.3.7.3、合并产生冲突

image

如上图所示,合并 user 分支到 master 分支时,产生了冲突;分支的状态也由 master 变成了 master|MERGING ,说明还没有合并成功。

合并冲突提示信息说明:

  • Merge conflict in hello.txt :在 hello.txt 中存在合并冲突。

  • Automatic merge failed:自动合并失败。

  • fix conflicts and then commit the result:需要处理冲突后再提交。

打开发生合并冲突的文件(本例为 hello.txt ),可以看到具体发生冲突的内容:

  • 在“<<<<<<<HEAD”和“=======”之间是当前分支的内容。

  • 在“=======”和“>>>>>>>”之间是要合并的内容。

4.3.7.4、合并冲突的原因

合并分支时,如果两个分支在同一个文件的同一个位置做了不同的修改,就会产生冲突。

因为Git 无法自动替我们决定使用哪一个,所以必须手动决定新内容。

4.3.8、解决冲突

4.3.8.1、手动处理冲突的内容

image

4.3.8.2、提交处理冲突后的内容

image

如上图所示,当冲突的内容被处理并提交后,分支的状态也由 master|MERGING 变成了 master,说明已经合并成功。

注意:此时使用的 git commit 命令不能带文件名。

4.3.8.3、注意事项

image

本例演示解决的是合并 user 分支到 master 分支时发生的内容冲突,冲突的地方在 master 分支,解决冲突的地方也是在 master 分支。

因此,如上图所示, user 分支的内容不会受到任何影响。

4.3.9、删除分支

image

 git branch -d 分支名

当某个分支没有存在必要的时候,可以将其删除。

注意:当要删除的分支是当前分支时,会报错:“error: cannot delete branch '当前分支名' used by worktree at '工作区路径'”;
这时只需要将当前分支切换为其他分支,就能成功删除。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/709507.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring 对 Junit4,Junit5 的支持上的运用

1. Spring 对 Junit4,Junit5 的支持上的运用 @目录1. Spring 对 Junit4,Junit5 的支持上的运用每博一文案2. Spring对Junit4 的支持3. Spring对Junit5的支持4. 总结:5. 最后:每博一文案 关于理想主义,在知乎上看到一句话:“他们并不是不懂别人口中的现实,他们只是不信,事…

Eclipase的JNnit导包报错

在使用Eclipase 创建项目时系统会自动帮我们生成一个module文件,JNnit单元测试时,记得删除自动生成的 module-info.java文件,不然会一直报错找不到 org

来玩 GitHub 啊,SSH 连接方式

Windows 11 git version 2.32.0.windows.2 GitHub 20240520 --今天找回了自己的 GitHub 账号密码,继续玩吧,再次加入 蓝星的开源软件基地。 使用邮箱注册的,找回密码也很方便。本文简要展示 按照官方文档的介绍 使用 SSH 连接 GitHub 的过程。 简述为:创建SSH密钥对 公钥注…

来玩 GitHub 啊,SSH 连接

今天找回了自己的 GitHub 账号密码,继续玩吧,再次加入 蓝星的开源软件基地。 使用邮箱注册的,找回密码也很方便。本文简要展示 按照官方文档的介绍 使用 SSH 连接 GitHub 的国产。主要文档 1、Connecting to GitHub with SSH https://docs.github.com/en/authentication/con…

ABC 354 (atcoder beginer 354) D、E、F

D检查: 1. 有可能是推导式有问题,比如-/+写错 2. x,y A、B、C、D 顺序可能搞反了 不要盲目调试,先用人眼看一下代码的情况,找一下错误很简单的找规律的题目。 很不能理解过的人,就这些。 x方向,y方向,都是4行/列,一个规律的循环。求(0,0)到(x,y)中的黑色块: 第0-3…

BUUCTF-WEB(21-25)

[HCTF 2018]admin 这道题目就是admin说明得管理员登录 那我直接创一个admin的账号但是显示已经存在了说明用户名就是admin,然后我们直接爆破,也是爆破出来密码就是123直接登录[MRCTF2020]你传你🐎呢 这个题就是文件上传,我们MIME绕过,后缀名都被ban了,我们上传.htaccess…

5.8-随堂练习1

1992年,姜万勐 看到 MPEG芯片 Epiphany – 用MPEG1 把图像和声音同时存储在一张小光盘上 VCD(Video Compact Disc)。 1993年9月 万燕第一批1000台VCD机下线。 几乎都被国内外家电公司买去解剖做样机 万燕VCD 100% 市场份额 1995年 各路仿制的VCD机大举进军市场,竞争激烈。 …

5.8-随堂练习-小组练习2

结合本小组项目写下能想到的所有 SWOT答案: 【第九组】 在充电桩电控系统项目中,可以想到以下所有的SMOT(Strengths, Weaknesses, Opportunities, Threats): Strengths (强项):功能丰富:系统具有多种功能,包括充电桩管理、用户充电、支付功能等。 易用性:界面设计简洁…

foobar2000 v2.1.5 汉化版

foobar2000 v2.1.5 汉化版 -----------------------【软件截图】---------------------- -----------------------【软件介绍】---------------------- foobar2000 是一个 Windows 平台下的高级音频播放器.包含完全支持 unicode 及支持播放增益的高级标签功能. 特色: * 支持的…

学习笔记

CPP:函数指针定义方法 int (func)(int i); int (p)(int)=func

C123【模板】扩展域并查集 P1892 [BOI2003] 团伙

视频链接: P1892 [BOI2003] 团伙 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)// 扩展域并查集 #include <iostream> #include <cstring> #include <algorithm> using namespace std;int n,m,a,b,s; int p[2005];int find(int x){return p[x]==x?x:p[…

Hadoop集群模式的搭建之四:运行Hadoop集群

格式化NameNode 当第一次启动HDFS时要进行格式化,将NameNode上的数据清零,否则会缺失DataNode。以后启动无需再格式化,只要运行过Hadoop集群,其工作目录(/usr/local/src/hadoop/tmp)中就会有数据。如果需要重新格式化,则在重新格式化之前一定要先删除工作目录下的数据,…