【Git】创建,切换分支

devtools/2025/3/10 10:54:56/

理解分支

这里开始介绍Git的杀手级功能之一:分支。

分支就是科幻电影里的平行宇宙,当你正在电脑前努力学习C++的时候,另一个你正在另一个平行宇宙里努力学习JAVA。

如果两个平行宇宙互不干扰,那对现在的你也没啥影响。不过,在某个时间点,两个平行宇宙合并了,结果,你既学会了C++又学会了JAVA!

在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就可以理解为是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。

再来理解一下HEAD,HEAD严格来说不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是当前分支。HEAD可以指向其他分支,被指向的分支就是当前正在工作的分支

每次提交,master分支都会向前移动一步,这样,随着你不断提交,master分支的线也越来越长,而HEAD只要一直指向master分支即可指向当前分支。

通过查看当前的版本库,我们也能清晰的理出思路:
在这里插入图片描述
在这里插入图片描述

创建分支

Git支持我们查看或创建其他分支,在这里我们来创建第一个自己的分支dev,对应的命令为:

$ git branch  #查看当前本地所有分支
* mastergit branch dev  #新建分支devgit branch dev
* master

当我们创建新的分支后,Git新建了一个指针叫dev,* 表示当前HEAD指向的分支是master分支
另外,可以通过目录结构发现,新的dev分支:

$ ls.git/refs/heads/
dev  master$ cat.git/refs/heads/*
7bc0dbb416db4d1f714f8519cf744a744a0a69ff
7bc0dbb416db4d1f714f8519cf744a744a0a69ff

发现目前dev和master指向同一个修改。
并且也可以验证下HEAD目前是指向master的。

$ cat.git/HEAD
ref: refs/heads/master

一张图总结:

在这里插入图片描述

(此处有分支关系图,展示新建dev分支时HEAD、master、dev和提交线的关系)

切换分支

那如何切换到dev分支下进行开发呢?

使用git checkout命令即可完成切换

示例如下:

$ git checkout dev
Switched to branch 'dev'$ git branch 
* devmaster$ cat.git/HEAD
ref: refs/heads/dev

在这里插入图片描述

(此处有分支关系图,展示切换到dev分支后HEAD、master、dev和提交线的关系)

我们发现HEAD已经指向了dev,就表示我们已经成功的切换到了dev上!

接下来,在dev分支下修改ReadMe文件,新增一行内容,并进行一次提交操作:

$ vim ReadMe
$ cat ReadMe
hello bit
hello git
hello world
hello version1
hello version2
hello version3
write New content for new branch dev
$ git add.
$ git commit -m"modify ReadMe on branch dev"
[dev f748c2d] modify ReadMe1 file changed, 1 insertion(+)

现在,dev分支的工作完成,我们就可以切换回master分支:

$ git checkout master
Switched to branch 'master'
hyb@139-159-150-152:~/gitcode$ cat ReadMe
hello bit
hello git
hello world
hello version1
hello version2
hello version3

切换回master分支后,发现ReadMe文件中新增的内容不见了!!赶紧再切回dev看看:

hyb@139-159-150-152:~/gitcode$ git checkout dev
Switched to branch 'dev'
hyb@139-159-150-152:~/gitcode$ cat ReadMe
hello bit
hello git
hello world
hello version1
hello version2
hello version3
write New content for new branch dev

在dev分支上,内容还在。为什么会出现这个现象呢?我们来看看dev分支和master分支指向,发现两者指向的提交是不一样的:

$ cat.git/refs/heads/dev
bdaf528ffbb8e05aee34d37685408f0e315e31a4$ cat.git/refs/heads/master
5476bdeb12510f7cd72ac4766db7988925ebd302

看到这里就能明白了,因为我们是在dev分支上提交的,而master分支此刻的提交点并没有变,此时的状态如图如下所示。
在这里插入图片描述
当切换到master分支时,HEAD就指向了master,当然看不到提交了。


http://www.ppmy.cn/devtools/165982.html

相关文章

单体架构、集群、分布式、微服务的区别!

目录 一、 单体架构 🧱二、 集群 👯‍♀️👯‍♂️三、 分布式架构 🏢四、 微服务架构 🏘️五、总结 🌟我的其他文章也讲解的比较有趣😁,如果喜欢博主的讲解方式,可以多多…

【第二十六周】:HRNet:用于人体姿态估计的深度高分辨率表征学习

摘要 本篇博客介绍了HRNet(High-Resolution Network),这是一种用于密集预测任务(如人体姿态估计、图像分割)的深度学习模型,其核心思想是通过全程保持高分辨率特征和多分辨率分支动态交互,解决…

nvm list available为空

nvm list available为空 该问题主要是因为nvm 获取不到node导致,排查网络问题外,可能就是由于nvm环境变量配置问题导致,本次我这个问题就是由于环境变量配置缺少导致的。 第一步:排查并排除了网络问题。 第二步:排查环…

AI学习有感

和前辈聊天,谈到了现在的ai技术,这里对那天的谈话进行总结: AI是无状态的 我们在使用ai时有时候会有一个错觉,认为和ai聊天久了,ai就会像人与人之间交流一样,会保留一种对聊天对象的认知状态,这…

openharmory-鸿蒙生态设备之间文件互传发现、接入认证和文件传输

软件版本 OpenHarmony系统版本基线:基于 OpenHarmony-v5.0.0-Release。 图库应用版本:基于OpenHarmony-v5.0.0-Release。 文件管理器应用版本:基于OpenHarmony-v5.0.0-Release。 7 用户历程图 8 设备发现 8.1 设备交互流程图 8.2 设备发…

腾讯云大模型知识引擎LKE+DeepSeek结合工作流升级智能客服

前言 在上期教程中介绍了,如何通过知识库打造智能客服系统,本期教程将介绍如何结合工作流,打造更具交互性的,能够远程调用API的智能客服系统。 本图文教程的视频版已发布:腾讯云大模型知识引擎LKEDeepSeek结合工作流…

Python 自动化探索性数据分析(EDA)工具

1. Pandas Profiling 功能特点: 自动生成详细的统计报告,包含数据概览、单变量分析、相关性矩阵、缺失值分析等。支持交互式 HTML 报告,可导出为 PDF 或其他格式。适合快速生成数据集的全面摘要。 使用示例:import pandas as pd …

11-Agent中配置自己的插件

目录 关键词 摘要 速览 配置和集成自定义插件 使用AI插件在直播间绘制图像 API接口调用及配置说明 创建和配置API工具以生成图像 编写和配置参数及API调用说明 如何配置和使用API进行HTTP请求 配置和测试API插件的步骤 思维导图 发言总结 要点回顾 如何配置一个专…